第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;
}