(1)b是一個(gè)局部結(jié)構(gòu)體變量,賦初值,顯然是結(jié)構(gòu)體對應(yīng)賦值,因此空1應(yīng)該填入:a。(2)空2是將字符串"LiSi"賦值給b的成員name,因此應(yīng)該填入:b.name。(3)空3顯然是輸出b的3門課成績,因此應(yīng)該填入:score[i]。
二、改錯(cuò)題
給定程序是建立一個(gè)帶頭結(jié)點(diǎn)的單向鏈表,并用隨機(jī)函數(shù)為各結(jié)點(diǎn)賦值。函數(shù)fun的功能是將單向鏈表結(jié)點(diǎn)(不包括頭結(jié)點(diǎn))數(shù)據(jù)域?yàn)榕紨?shù)的值累加起來,并且作為函數(shù)值返回。
請改正程序中的錯(cuò)誤,使其能得出正確的結(jié)果。
注意:不要改動(dòng)main函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
#include <stdio.h>
#include <stdlib.h>
typedef struct aa
{int data; struct aa*next;}NODE;
int fun(NODE*h)
{
int sum=0;
NODE *p;
p=h;
while(p)
{
if(p->data%2==0)
sum+=p->data;
p=h->next;
}
return sum;
}
NODE *creatlink(int n)
{
NODE *h,*p,*s,*q;
int I,x;
h=p=(NODE *)malloc(sizeof(NODE));
for(I=1;I<=n;I++)
{
s=(NODE*)malloc(sizeof(NODE));
s->data=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,"THE LIST :\n HEAD");
while(p)
{
fprintf(pf,"->%d",p->data);
p=p->next;
}
fprintf(pf,"\n");
}
outresult(int s,FILE *pf)
{
fprintf(pf,"The sum of even numbers :
%d\n",s);
}
main()
{
NODE *head; int even;
head=creatlink(12);
head->data=9000;
outlink(head,stdout);
even=fun(head);
printf("The result :\n");
outresult(even, stdout);
}
【答案與解析】
相關(guān)推薦:2009年9月計(jì)算機(jī)等級考試二級C語言模擬試題(1)北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |