1、国家二级( C语言)机试模拟试卷 354及答案与解析 一、程序填空题( 30分) 1 给定程序通过定义并赋初值的方式,利用结构体变量存储了一名学生的学号、姓名和 3门课的成绩。函数 fun的功能是将该学生的各科成绩都乘以一个系数 a。 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在考生文件夹下的 BLANKl C中。 不得增行或删行,也不得更改程序的结构 ! #include typedef struct int num; char name9; float score3; STU; void show(STU tt) int i; printf(“
2、%d %s : “,tt.num,tt.name); for(i=0; i【 2】 *=a; main() STU std= 1,“Zhanghua“,76.5,78.0,82.0 ; float a; printf(“nThe original number and name and scores :n“); show(std); printf(“nInput a number : “); scanf(“%f“, /*found*/ modify(【 3】 ,a); printf(“nA result of modifying :n“); show(std); 二、程序修改题( 30分) 2
3、 给定程序 MODll C是建立一个带头结点的单向链表,并用随机函数为各结点赋值。函数 fun的功能是将单向链表结点 (不包括头结点 )数据域为偶数的值累加起来,并且作为函数值返回。 请改正函数 fun中指定部位的错误,使它能得出正确能结果。 注意:不要改动 main函数,不得增行或 删行,也不得更改程序的结构 ! #include #include typedef struct aa int data; struct aa *next;NODE; int fun(NODE *h) int sum = 0 ; NODE *p; /*found*/ p=h;-next; while(p) if(
4、p-data%2=0) sum +=p-data; /*found*/ p=p-next; return sum; NODE *creatlink(int n) NODE *h, *p, *s; int i; h=p=(NODE *)malloc(sizeof(NODE); for(i=1; idata=rand()%16; s-next=p-next; p-next=s; p=p-next; p-next=NULL; return h; outlink(NODE *h, FILE *pf) NODE *p; p = h-next; fprintf(pf ,“nnTHE LIST :nn HE
5、AD “); while(p) fprintf(pf ,“-%d “,p-data); p=p-next; fprintf (pf,“n“); outresult(int s, FILE *pf) fprintf(pf,“nThe sum of even numbers : %dn“,s); main() NODE *head; int even; head=creatlink(12); head-data=9000; outlink(head , stdout); even=fun(head); printf(“nThe result :n“); outresult(even, stdout
6、); 三、程序设计题( 40分 ) 3 请编写函数 fun,函数的功能是;将 M行 N列的二维数组中的数据,按行的顺序依次放到一维数组中,一维数组中数据的个数存放在形参 n所指的存储单元中。 例如,二维数组中的数据为: 则一维数组中的内容应是: 33 33 33 33 44 44 44 44 55 55 55 55。 注意:部分源程序在文件 PR001 C中。 请勿改动主函数main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。#include void fun(int (*s)10, int *b, int *n, int mm, int nn)main()int
7、w1010 = 33,33,33,33,44,44,44,44,55,55, 55,55,i,j ; int a100 = 0, n = 0 ;void NONO (); printf(“The matrix:n“); for(i = 0 ; i scorei *=a;”。 第三空: modify函数的第一个参数是指针,故调用该函数时第一个参数应该是变量 std的地址 “ p=p- next; 【试题解析】 ( 1)根据题干中求得除了头结点之外的结点数据域中的最大值,头指针 h,工作指针 p指向头结点的下一个结点,所以第一个标识下的 “p=h;”指向头结点应该改为指向下一个结点 “p=h-next;”。 ( 2)工作指针 p,利用 p实现对链表的遍历, p表示指向链表的当前结点,所以指向下一个结点应该是 “p=p- next;”。 三、程序设计题( 40分) 3 【正确 答案】 int i,j; for(i=0;imm;i+) for(j=0;jnn;j+) b*n=*(*(s+i)+j); *n=*n+1; 【试题解析】 ( 1)利用两重循环,依次取矩阵中的元素。 ( 2)其中注意指针数组与数组指针的区别,其中数组指针 s,它指向包含 4个元素的一维数组。其数据元素的表示方式为: “*(*(s+i)+j)”。