您的位置:首页 > 其它

读取文件并找出年龄最大的N个人-兰亭集市笔试题

2016-03-21 15:22 239 查看
C++ code:

#include <iostream>
#include <fstream>
#include <map>
#include <string>
#include <algorithm>

using namespace std;

int main()
{
multimap<int,string> agemap;//以年龄为键,以个人信息为值,年龄必有重复,定义成multimap可自动排序
ifstream infile("persons.txt");//为ifstream对象提供文件名作为初始化式,就相当于打开了特定的文件,不用再调用open函数
if(!infile)
{
cout<<"Open file error!"<<endl;
}

string textline;
int age;
string::reverse_iterator rcomma;//string类型反向迭代器,用于指向反向搜索找到的第一个逗号
while(getline(infile,textline))//getline函数将istream参数作为返回值,可用作读取结束判断条件
{
rcomma=find(textline.rbegin(),textline.rend(),',');//rcomma指向从后往前的最后一个逗号
age=atoi(string(rcomma.base(),textline.end()).c_str());//string转int,rcomma.base()表示将反向迭代器rcomma转换为从前往后移动的普通迭代器
agemap.insert(make_pair(age,textline));//将年龄和完整信息插入multimap
}

multimap<int,string>::reverse_iterator map_it=agemap.rbegin();//从后往前输出

int N=10;//假定要输出年龄最大的前10个
while(map_it!=agemap.rend() && N-- >0)//按年龄降序输出元素
{
cout<<map_it->second<<endl;
++map_it;
}

return 0;
}


 

persons.txt

Ted Elliott,9876541198611121512,27
Peter Twist,52478198901243122,24
Terry Rossio,456871198804096012,25
George Marshall Ruge,510402198904070919,24
Brian Morris,51068119830104411X,30
Christopher Masterson,432502198908193032,24
Mel Colm-Cille Gerard Gibson,431102198911046233,24
Tim,511621198603095910,27
gdfgdf,371326198806230018,25
gdfg,41150219871015966X,26
gdfdf,620422198801191911,25
gdfgfd,411325198710241333,26
gdff,140522198804301013,25
gdfg,230204198801180714,25
dfgfd,510704198706063514,26
gfdgdf,610424198906172881,24
gdfgfd,513922198511210031,28
uykuy,320911198901061214,24
jghjj,51302919890906659X,24
jhhjh,612731198809280436,25
jhgjhg,650103198902056022,24
jghg,51070319790525972X,34
jghjh,510681198810130315,25
hgjhg,510304198706071010,26
jghjhg,320382198708300431,26
jhgjg,340321198903154709,24
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: