数据结构课程设计以小组为单位进行答辩,每个小组有一个唯一正整数表示的的编号和四个成员。 答辩成绩采用排名制,答辩结束后每个小组都提交一份答辩成绩表,该成绩表按照排名从高到低的顺序列出所有小组编号。 例如,小组编号最大值为5,2号小组提交的成绩表数据为{5 1 2 4 3 },则5号小组排名第一,1号小组排名第2,以此类推。 每个小组最终答辩成绩排名按照所有组所提交排名之和重新排序,和越小排名越高,名次从高到低分别为1,2,3,…。 请你帮老师统计下每个小组的最终排名。
输入格式:
输入在一行中给出正整数N(N≤10),为小组个数。 随后N行,按照小组编号i(1≤i≤N)递增顺序每行首先给出第i个小组四个成员的姓名,中间以空格分隔, 然后给出一个小组提交的答辩成绩表,由N个正整数组成,中间以空格分隔,分别对应排名从高到低的小组编号。 其中姓名为长度不超过20的不包含空白字符的非空字符串。
输出格式:
按照最终排名非递增次序,每行先给出名次,然后按照输入顺序输出对应小组四个成员的姓名,中间以一个空格分隔。 如果小组最终排名有相同,则再按照小组编号递增顺序输出。
输入样例:
5
xiaozhao zhangwuji zhaomin zhouzhiruo 2 3 1 5 4
huangrong guojing guofu guoxiang 2 3 5 1 4
yangguo xiaolongyu limochou laowantong 3 2 1 4 5
yangkang monianci ouyangxiu zhoubotong 2 3 1 5 4
yuanchengzhi qingqing wenyi gongzhu 3 2 1 4 5
输出样例:
1 huangrong guojing guofu guoxiang
2 yangguo xiaolongyu limochou laowantong
3 xiaozhao zhangwuji zhaomin zhouzhiruo
4 yuanchengzhi qingqing wenyi gongzhu
5 yangkang monianci ouyangxiu zhoubotong
#define N 11
#include
struct score
{
char a[21];
char b[21];
char c[21];
char d[21];
int l;
int m;
int n;
int o;
int p;
}a[N],t;
int main(void)
{
int n,b[11]={0},i,j;
int k;
scanf("%d\n",&n);
for(i=0;i<n;i++)
{
if(i<n-1)
scanf("%s %s %s %s %d %d %d %d %d \n",a[i].a ,a[i].b ,a[i].c ,a[i].d ,&a[i].l ,&a[i].m ,&a[i].n ,&a[i].o ,&a[i].p);
else
scanf("%s %s %s %s %d %d %d %d %d ",a[i].a ,a[i].b ,a[i].c ,a[i].d ,&a[i].l ,&a[i].m ,&a[i].n ,&a[i].o ,&a[i].p);
}
for(i=0;i<n;i++)
for(j=0;j<n;j++)
{
if(a[j].l ==i+1)
b[i]+=1;
else if(a[j].m ==i+1)
b[i]+=2;
else if(a[j].n ==i+1)
b[i]+=3;
else if(a[j].o ==i+1)
b[i]+=4;
if(a[i].p==i+1)
b[i]+=5;
/*else if(a[i].q==i+1)
b[i]+=6;
else if(a[i].r==i+1)
b[i]+=7;
else if(a[i].s==i+1)
b[i]+=8;
else if(a[i].t==i+1)
b[i]+=9;
else
b[i]+=10;*/
}
for(i=0;i<n;i++)
{
for(j=0;j<n-i-1;j++)
if(b[j]>b[j+1])
{
t=a[j];
a[j]=a[j+1];
a[j+1]=t;
k=b[j];
b[j]=b[j+1];
b[j+1]=k;
}
}
for(i=0;i<n;i++)
printf("%d %s %s %s %s\n",i+1,a[i].a ,a[i].b ,a[i].c ,a[i].d );
}
通讯录中的一条记录包含下述基本信息:朋友的姓名、出生日期、性别、固定电话号码、移动电话号码。 本题要求编写程序,录入N条记录,并且根据要求显示任意某条记录。
输入格式:
输入在第一行给出正整数N(≤10);随后N行,每行按照格式姓名 生日 性别 固话 手机给出一条记录。其中姓名是不超过10个字符、不包含空格的非空字符串;生日按yyyy/mm/dd的格式给出年月日;性别用M表示“男”、F表示“女”;固话和手机均为不超过15位的连续数字,前面有可能出现+。
在通讯录记录输入完成后,最后一行给出正整数K,并且随后给出K个整数,表示要查询的记录编号(从0到N−1顺序编号)。数字间以空格分隔。
输出格式:
对每一条要查询的记录编号,在一行中按照姓名 固话 手机 性别 生日的格式输出该记录。若要查询的记录不存在,则输出Not Found。
输入样例:
3
Chris 1984/03/10 F +86181779452 13707010007
LaoLao 1967/11/30 F 057187951100 +8618618623333
QiaoLin 1980/01/01 M 84172333 10086
2 1 7
输出样例:
LaoLao 057187951100 +8618618623333 F 1967/11/30
Not Found
#define N 12
#include
struct number
{
char name[21];
char birthday[21];
char c;
char a[21];
char b[21];
}s[N];
int main(void)
{
int n;
scanf("%d",&n);
int i,k,a[N]={-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1},j;
for(i=0;i<n;i++)
scanf("%s %s %c %s %s",s[i].name ,s[i].birthday ,&s[i].c ,s[i].a ,s[i].b );
scanf("%d",&k);
for(i=0;i<k;i++)
scanf("%d",&a[i]);
for(i=0;i<k;i++)
{
if(a[i]<n&&a[i]>=0)
printf("%s %s %s %c %s\n",s[a[i]].name ,s[a[i]].a ,s[a[i]].b ,s[a[i]].c,s[a[i]].birthday );
else
printf("Not Found\n");
}
}