C语言结构体与共用体练习题


第1关:程序填空(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;
			  }		                        //第j个候选人票数加1
					   

		
	}
	
	printf("投票结果:\n");
	printf("姓名      票数\n");
	for(j=0;j<5;j++)
		
		/***** 在以下一行填写代码 *****/
		 printf("%-10s%d\n",     leader[j].name,leader[j].count         );     //输出各候选人的名字和票数
		 

		 
	return 0;
}

在这里插入图片描述

第2关:程序填空(2)

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

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

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

代码如下:

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

STD fun(STD std[], int n)
{
	
	STD max; int i;
	
	/***** 在以下一行填写代码 *****/
	max=       std[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关:程序填空(3)

编程要求
请仔细阅读右侧代码,结合相关知识,在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 **********/
	int i;
	*s=a[0];
	for(i=0;i<N;i++)
	if((s->s)>s[i].s)
	{
		*s=a[i];
	}
	
	/********** 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;
}

在这里插入图片描述


  • 5
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值