#include<cmath>
#include<algorithm>
#include<cstring>
#include<iostream>
#include<stack>
#include<vector>
#include<queue>
#include<string>
#include<map>
using namespace std;
//100min
//耗时于思路、重制代码,大部分时间用于提高算法效率
/*************************
**题意:给出一堆富豪(10^6个)的年龄和资产,要查询某年龄区间内的m个富豪,最多查1000次
**要求先按资产从大到小,再按年龄从小到大,再按字母序
*************************/
/************************
**求解:如果按照要求排序,显然为nlogn,不会超时
**但是如果要查询1000次,做遍历查询显然超时
**故结合题目特点:年龄最多0-200,查询年龄为区间,只需要查出m个排在前面的富豪。
**故把各富豪按年龄分到各自年龄vector中
**对各年龄数组进行排序,先按资产,后按字母序
**每个年龄数组维持一个当前最大值
**要查询时,从agemin数组查到agemax数组,从各数组的最大值中 找到最大值
**这样查询1k次,最多需要1k*200=2*10^5次。
************************/
/***
笔记:
★sort、cmp的用法
★不确定数组的个数时,尽量用vector而不是预设数组大小。
★先分析时间复杂度,再开始写代码
***/
#define M 100005
struct People
{
string name;
int age;
int weigh;
};
//struct People people[205][M];
vector<struct People> people[205];
bool cmp(struct People a,struct People b) // a<b是递增,a>b是递减
{
if(a.weigh > b.weigh)
return true;
else if(a.weigh==b.weigh)
{
if(a.name < b.name)
return true;
else return false;
}
else return false;
}; //没有cmp则默认为递增
int an[205];
int main()
{
int n,k,i,a,w;
string s;
memset(an,0,sizeof(an));
scanf("%d%d",&n,&k);
struct People p;
for(i=0;i<n;i++)
{
cin>>s>>a>>w;
p.name=s;
p.age=a;
p.weigh=w;
people[a].push_back(p);
}
for(i=1;i<205;i++)
sort(people[i].begin(),people[i].end(),cmp);
int j,m,amin,amax;
vector<People> ans;
int wmax;
struct People maxp;
int nown[205];
int select;
for(i=0;i<k;i++)
{
scanf("%d%d%d",&m,&amin,&amax);
ans.clear();
memset(nown,0,sizeof(nown));
while(m>0)
{
wmax=-2000000;
for(j=amin;j<=amax;j++)
{
//printf("j=%d, nown=%d, an=%d \n",j,nown[j],an[j]);
//某年龄的第nown个与最大值做判断,挑出最大的。
if(nown[j] < people[j].size() && people[j][ nown[j] ].weigh > wmax)
{
wmax = people[j][ nown[j] ].weigh;
maxp = people[j][ nown[j] ];
select = j;
}
}
if(wmax == -2000000)
break;
ans.push_back(maxp);
nown[select]++;
m--;
}
printf("Case #%d:\n",i+1);
if(ans.size()==0)
cout<<"None"<<endl;
for(j=0;j<ans.size();j++)
{
cout<<ans[j].name<<" "<<ans[j].age<<" "<<ans[j].weigh<<endl;
}
}
return 0;
}
PAT 1055. The World's Richest (25) 年龄排序问题(O(n)排序)
原创
©著作权归作者所有:来自51CTO博客作者breakDawn的原创作品,请联系作者获取转载授权,否则将追究法律责任
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
排序算法之计数排序的优化
排序算法之计数排序的优化
数组 计数排序 最小值 -
【C】排序算法
文章介绍了几种常用的排序,包括其实现思路与具体代码实现。
排序 算法 代码分析 -
1055. The World's Richest (25)
总共 N个人,有K中排行;N行 名字 年龄 身价……K行 要输出几人 最小年龄 最大年龄……如果有符合条件的输出前几个即以内对应的姓名、年龄、身价 ,顺序身价>=年龄>=姓名 否则None
C++ pat_advanced_level sort #include sed -
PAT 甲级 1055 The World's Richest
1055 The World's
PAT甲级 1055 #include 数据 -
A1055 The World's Richest (25 分| 排序,附详细注释,逻辑分析)
写在前面思路分析
A1055 结构体 自定义排序 数组