读取文件并找出年龄最大的N个人-兰亭集市笔试题
2016-03-21 15:22
239 查看
C++ code:
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
#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
相关文章推荐
- 数组复制引用问题
- oracle 数据库 查询结构拼接输出到本地文件
- 微信公众帐号开发教程第1篇-引言
- 集成银联3.30
- 读书随笔_2016.3.18
- TableViewController 运用时会出现多余的空白行,非常难看
- 第三周作业(一)
- 采用重写tostring方法使ComboBox显示对象属性
- 囚犯猜帽子问题
- 倒计时(原生写法)
- 剑指 offer代码解析——面试题26复杂链表的复制
- 剑指 offer代码解析——面试题26复杂链表的复制
- UIPickerView的使用
- Describe major crisis
- Android启动过程深入解析
- 敏捷开发解决方案
- mongodb group 查询
- 海量文本数据保存到数据库思路
- 关于测试的一些基本概念和术语
- 【matlab】MATLAB程序调试方法和过程