educoder结构体和共用体

程序填空1
任务描述
本关任务:程序的功能是模拟选举并统计候选人得票数。请填写程序使得程序能正确运行得出结果。

相关知识
相关知识略

编程要求
请仔细阅读右侧代码,结合相关知识,在右边提示区域内进行代码补充,完成编写程序填空(1)的小程序。

测试说明
平台会对你编写的代码进行测试:

测试输入:
zhang
zhang
sun
li
yang
zhao
zhang
zhang
zhang
zhang

预期输出:
投票结果:
姓名 票数
zhang 6
sun 1
li 1
yang 1
zhao 1

#include <stdio.h>
#include <string.h>

struct  person
{
	char name[8];
	int count;
};

int main()
{
	int i,j;
	char name[8];
	struct  person leader[5]={"zhang",0,"sun",0,"li",0,"yang",0,"zhao",0 };

	for(i=1;i<=10;i++)
	{
		/***** 在以下一行填写代码 *****/
	  //输入候选人姓名
			char n[8] ;
			scanf("%s",&n);
		 	for(j=0;j<5;j++)
		/***** 在以下一行填写代码 *****/
		{
				if(strcmp(n, leader[j].name )==0 )       //若第j个候选人名字与输入的名字相同
			  {
			  	leader[j].count++;	
			  
			  	break;
			  }	
		}
		
	}
	
	printf("投票结果:\n");
	printf("姓名      票数\n");
	for(j=0;j<5;j++)
		
		/***** 在以下一行填写代码 *****/
		 printf("%-10s%d\n", leader[j].name,leader[j].count        );     //输出各候选人的名字和票数
		 

		 
	return 0;
}

程序填空2
本关任务:给定程序中,函数fun()的功能功能是:将形参std所指结构体数组中年龄最大者的数据作为函数值返回,并在main函数中输出。请将程序补充完整,使程序得出正确的结果。 注意不得增行或删行,也不得更改程序的结构!

相关知识
相关知识略

编程要求
请仔细阅读右侧代码,结合相关知识,在右边提示区域内进行代码补充,完成编写程序填空(2)的小程序。

测试说明
平台会对你编写的代码进行测试:

预期输出:
输出最大年龄的姓名和年龄。

开始你的任务吧,祝你成功!

#include <stdio.h> 
#include<string.h>
typedef struct 
{
	char name[10]; 
	int age; 
}STD;

STD fun(STD std[], int n)
{
	
	STD max; int i;
	
	/***** 在以下一行填写代码 *****/
	/*max.name ="m";
	max.age = 0 ;
	*/
//	max= {"m",0};
	strcpy(max.name,"myna");
	max.age=0;


	for(i=1; i<n; i++)
		
	/***** 在以下一行填写代码 *****/
	if(max.age<std[i].age          )
		max=std[i];
	

	
	return max;
}
int main( )
{
	STD std[5]={"aaa",17,"bbb",16,"ccc",18,"ddd",17,"eee",15 };
	STD max;
	max=fun(std,5);
	printf("The result:\n");
	
	/***** 在以下一行填写代码 *****/
	printf("Name : %s, Age : %d\n",     max.name      ,max.age);
	

	
	return 0;
}

程序填空3
本关任务:已知学生的记录由学号和学习成绩构成,N名学生的数据已存入名为a结构体数组中。函数fun的功能是:找出成绩最低的学生记录,通过形参返回到主函数(规定只有一个最低分)。

相关知识
相关知识略

编程要求
请仔细阅读右侧代码,结合相关知识,在Begin-End区域内进行代码补充,完成编写程序填空(3)的小程序。

测试说明
平台会对你编写的代码进行测试:

预期输出:
输出成绩最低的学生记录。

#include <stdio.h>
#include <string.h>
#define N 10
typedef struct ss
{
	char num[10]; 
	int s; 

} STU;
	
void fun( STU a[], STU *s )
{
	/********** Begin **********/
	strcpy(a[0].num,s->num) ;
	s->s=a[0].s;
	
	for ( int i=1; i< N; i++ )
	{
		if((s->s)>a[i].s)
		{
			strcpy(s->num,a[i].num);
			s->s=a[i].s;
		}
		
	}
	

	/********** End **********/
}


int main ( )
{
	STU a[N]={ {"A01",81},{"A02",89},{"A03",66},{"A04",87},{"A05",77},
				{"A06",90},{"A07",79},{"A08",61},{"A09",80},{"A10",71} }, m ;
	int i;
	
	printf("***** The original data *****\n");
	for ( i=0; i< N; i++ )
		printf("No = %s Mark = %d\n", a[i].num,a[i].s);
	
	fun ( a, &m );
	
	printf ("***** THE  RESULT *****\n");
	printf ("The lowest : %s , %d\n",m.num, m.s);
	
	return 0;
}
  • 17
    点赞
  • 55
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值