程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> pat 1055 區間前k個

pat 1055 區間前k個

編輯:C++入門知識

第二組數據比較大,如果單純排序直接檢索會超時,因為每次都是對所有數據進行遍歷。

N/200=500,說明同一年齡最多可以有500個人,而M=100比較小,意味著同一年齡100以後的人都不會被搜到。

 

#include<iostream>
#include<cstring>
#include<cstdio>
#include <algorithm>
using namespace std;
struct node{
	char name[10];
	int age,worth;
}a[100005];
int b[20005];
int c[205];
bool cmp2(const node& p,const node& q){
	if(p.worth==q.worth)
	{
		if (p.age==q.age)
		{
			return strcmp(p.name,q.name)<=0;
		}
		return p.age<q.age;
	}
	return p.worth>q.worth;
}
int main()
{
	int n,q,i,M,ma,mb,txt=1,len;
	while(~scanf("%d %d",&n,&q))
	{
		memset(c,0,sizeof(c));
		for (i=0;i<n;++i){
			scanf("%s%d%d",a[i].name,&a[i].age,&a[i].worth);
		}
		sort(a,a+n,cmp2);
		for (len=i=0;i<n;++i){
			if (c[a[i].age]<=100)
			{
				b[len++]=i;
				c[a[i].age]++;
			}
		}
// 		printf("----\n");
// 		for (i=0;i<n;++i){
// 			printf("%s %d %d\n",a[b[i]].name,a[b[i]].age,a[b[i]].worth);
// 		}
		while(q--){
			scanf("%d%d%d",&M,&ma,&mb);
			if(ma>mb){
				ma^=mb;
				mb^=ma;
				ma^=mb;
			}
			printf("Case #%d:\n",txt++);
			int cnt=0;
			for (i=0;i<len&&cnt<M;++i){
				if(a[b[i]].age>=ma&&a[b[i]].age<=mb){
					printf("%s %d %d\n",a[b[i]].name,a[b[i]].age,a[b[i]].worth);
					cnt++;
				}
			}
			if(cnt==0){
				printf("None\n");
			}
		}
	}
	return 0;
}

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved