【问题描述】编写一个程序,输入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 <stdlib.h>
#include<stdio.h>
#include<string.h>
//typedef struct user
struct user
{
char name[15];
char tele[15];
}t,user[30];
int main()
{
int n;
int i;
int l;
scanf("%d",&n);
for(i = 0; i < n; i++)
{
scanf("%s",user[i].name);
scanf("%s",user[i].tele);
}
int j = 0;
for(i = 0; i<n-1;i++)
{
for(j = 0; j<n-i-1;j++)
{
if(strcmp(user[j+1].name,user[j].name)<0)
{
char temp[10];
char t[10];
strcpy(temp,user[j].name);
strcpy(t,user[j].tele);
strcpy(user[j].name,user[j+1].name);
strcpy(user[j].tele,user[j+1].tele);
strcpy(user[j+1].name,temp);
strcpy(user[j+1].tele,t);
}
}
}
for(i = 0; i < n; i++)
{
l = strlen(user[i].name);
if(l>=10)
{
l = 10;
}
user[i].name[l] = '\0';
l = strlen(user[i].tele);
if(l>=10)
{
l = 10;
}
user[i].tele[l] = '\0';
printf("%12s%12s\n",user[i].name,user[i].tele);
}
return 0;
}