zl程序教程

您现在的位置是:首页 >  其它

当前栏目

结构体与共用体

结构 共用
2023-09-11 14:20:01 时间

第1关:程序填空(1)

200

  • 任务要求
  • 参考答案
  • 评论47

任务描述

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

相关知识

相关知识略

编程要求

请仔细阅读右侧代码,结合相关知识,在右边提示区域内进行代码补充,完成编写程序填空(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++)
	{
		/***** 在以下一行填写代码 *****/
		scanf("%s",name);//输入候选人姓名					 
		 for(j=0;j<5;j++)
		/***** 在以下一行填写代码 *****/
			  if(strcmp(name,leader[j].name)==0)//若第j个候选人名字与输入的名字相同	  
		/***** 在以下一行填写代码 *****/
			        leader[j].count++;//第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)

200

  • 任务要求
  • 参考答案
  • 评论47

任务描述

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

相关知识

相关知识略

编程要求

请仔细阅读右侧代码,结合相关知识,在右边提示区域内进行代码补充,完成编写程序填空(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)

200

  • 任务要求
  • 参考答案
  • 评论47

任务描述

本关任务:已知学生的记录由学号和学习成绩构成,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 **********/
	int i;
    *s=a[0];
    for(i=0;i<N;i++){
        if(s->s>a[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;
}