2019-12-12(结构体附加题)

7-1 课程设计排名统计 (20分)(18分实在不想修改了)

数据结构课程设计以小组为单位进行答辩,每个小组有一个唯一正整数表示的的编号和四个成员。 答辩成绩采用排名制,答辩结束后每个小组都提交一份答辩成绩表,该成绩表按照排名从高到低的顺序列出所有小组编号。 例如,小组编号最大值为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<stdio.h>
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 );
}

标题7-2 通讯录的录入与显示 (30分)

通讯录中的一条记录包含下述基本信息:朋友的姓名、出生日期、性别、固定电话号码、移动电话号码。 本题要求编写程序,录入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<stdio.h>
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");
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值