【电话薄排序】

【问题描述】编写一个程序,输入N个用户的姓名和电话号码,按照用户姓名的词典顺序排列输出用户的姓名和电话号码。
【输入形式】用户首先在第一行输入一个正整数,该正整数表示待排序的用户数目,然后在下面多行输入多个用户的信息,每行的输入格式为:姓名 电话。以回车结束每个用户的输入。
【输出形式】程序输出排序后的结果。每行的输出结果格式也是: 姓名 电话。姓名和电话字段中间没有空格,要求用户姓名不能超过10个字符,超出10个字符时候只取前10个字符作为姓名。电话号码不能超过10位,超过10位时只按10位处理。输出姓名、电话字段各占12个字符宽,输出格式采用默认对齐方式。另外,用户的数量要求不超过50个。
【样例输入】
3
amethystic 1234567
amethyst 654321
wangwei 7645434
【样例输出】
####amethyst######654321
##amethystic#####1234567
#####wangwei#####7645434
【样例说明】程序根据用户姓名的词典顺序排序,最后按照姓名#电话的格式输出。另外,由于规定姓名和电话之间用空格分割,所以输入姓名时请将姓和名一起输入,中间不要有空格。另外输出时候程序将自动补齐12字符宽。程序输出结尾有个回车符。
【评分标准】完全正确为20分,每个测试点4分。提交程序文件名为telsort.c

#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include

#pragma warning (disable:4996)
using namespace std;

int main()
{

    map<string, string>m; int n; cin >> n; string name, tell;
    for (int i = 0; i < n; i++)
    {
        cin >> name >> tell;
        if (name.length() > 10)
            name = name.substr(0, 10);
        if (tell.length() > 10)
            tell = tell.substr(0, 10);
        m.insert(make_pair(name, tell));
    }
    for (map<string,string>::iterator it=m.begin();it!=m.end();it++)
    {
        printf("%12s%12s", (*it).first.c_str(), (*it).second.c_str());
        cout << endl;
    }
}

你可能感兴趣的:(重交cg,算法,c++)