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

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

posted @ 2014-08-26 15:20  疯狂的拖鞋  阅读(440)  评论(0编辑  收藏  举报