首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
给定程序modi1.C的主函数中,将a、b、c三个结点链成一个单向链表,并给各结点的数据域赋值,函数fun()的作用是:累加链表结点数据域中的数据作为函数值返回。 请改正函数fun中指定部位的错误,使它能得出正确的结果。 注意:不要改动ma
给定程序modi1.C的主函数中,将a、b、c三个结点链成一个单向链表,并给各结点的数据域赋值,函数fun()的作用是:累加链表结点数据域中的数据作为函数值返回。 请改正函数fun中指定部位的错误,使它能得出正确的结果。 注意:不要改动ma
admin
2018-09-27
71
问题
给定程序modi1.C的主函数中,将a、b、c三个结点链成一个单向链表,并给各结点的数据域赋值,函数fun()的作用是:累加链表结点数据域中的数据作为函数值返回。
请改正函数fun中指定部位的错误,使它能得出正确的结果。
注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。
1 #include<stdio.h>
2 typedef struct list
3 {int data;
4 struct list *next;
5 } LIST;
6 int fun(LIST*h)
7 {LIST *p;
8 /**********found**********/
9 int t;
10 p=h;
11 /**********found**********/
12 while(p)
13 {
14 /**********found**********/
15 t=t+p.data;
16 p=(*p).next;
17 }
18 return t;
19 }
20 main()
21 {LIST a,b,c,*h;
22 a.data=34;b.data=51;
23 c.data=87;c.next=’\0’;
24 h=&a;a.next=&b;b.next=&c;
25 printf(’’总和=%d\n’’,fun(h));
26 }
选项
答案
(1)int t改为int t=0; (2)while(*p)改为while(p) (3)t=t+p.data;改t=t+(*p).data
解析
本题中函数fun()的作用是:累加链表结点数据域中的数据作为函数值返回。这里数据是主函数中定义的a,b,c,但是要是链表结点的方式将其相加,其实也类似于普通的数据加减,只不过这里用到链表和结构体的话就要注意很多的细节问题,因为指针一直是C语言最难理解的一部分,很容易搞错它的使用方法。
(1)第一个错误在定义t时,t是数据结果,但是在一开始定义时,t应该定义为0的,这样才不会影响后面的数据结果,以免程序出现不必要的错误所以这里应该讲int t改为“int t=0”。
(2)第二个错误在fun函数中执行while条件时while的条件语句。
这里用“*p”,我们都知道这是指针的形式,而“*p”的意义是指针变量p所指向的变量的值,所以这里“*p”是一个具体的变量,而while(*p)的意义是“*p”不为空时就一直执行,但是这里根据题意我们需要的链表的地址来进行题目需要的链表的计算,而单向链表的结束的标志就是链尾,链尾的特征则是指向为空,这里指向为空指的是地址比阿娘,所以这里的终止条件不应该是p所指向的值为0,而是p的地址为空,所以“while(*p)”应该改为“while(p)”。
(3)第三个错误在fun()函数中的计算。我们都知道,链表与结构体是紧密相连的,这一题同样用到了,而且我们进行的也是链表结点的运算,自然要用到结构体成员变量的运算。但是在“t=t+p.data”这个运算时,“p.data”的意义是“p.data”这个指针变量,也就是说这是指针变量的运算,指针变量是跟结点变量不同的,我们需要的是结点的数据,而不是指向它的指针的数据,所以这里的运算是完全错误的,为了符合题意,我们应该要使用结点的结构体变量。即“=t+p.data”应该改为“t=t+(*p).data”。
转载请注明原文地址:https://kaotiyun.com/show/m8xp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
在数据结构中,从逻辑上可以把数据结构分为______。
在数据库理论中,数据库总体逻辑结构的改变,如修改数据模式、增加新的数据类型、改变数据间联系等,不需要相应修改应用程序,称为______。
若有程序fun(inta,intb){staticintc=0;c+=a+b;rerurnc;}main(){intx=5,y=3,z=7
若有说明chars1[30]="abc",s2[]="defghi";,则在使用函数strcat(s1,s2)后,结果是()。
有如下程序: main() {char ch[2][5]={"6937","8254"},*p[2]; int i,j,s=0; for(i=0;i<2;i++)p[i]=ch[i]; for(i=0;i<2;i++) for(j=0;p[i][j]!=’
下面定义的结构体类型包含3个成员,其中成员变量x用来存入整型数据,成员变量y用来存入实型数据,成员变量next是指向自身结构体的指针。请将定义补充完整。structstu{intx;【】【】next;}
在面向对象的方法中,______描述的是具有相似属性与操作的一组对象。
编制一个好的程序,首先要保证它的正确性和可靠性,还应强调良好的编程风格,在书写功能性注释时应考虑
Jackson结构化程序设计方法是英国的M.Jackson提出的,它是一种面向【】的设计方法。
随机试题
A.FEV1/FVC减低B.TLC减低C.RV/TLC升高D.FEV1占预计值百分比减低(2013年第141题)慢性阻塞性肺疾病的典型肺容量和通气功能的特征性变化是
气体灭菌可用于粉末注射剂。()
肩周炎的临床特点是
精子在体内主要贮存在
根据有关法律法规规定,因科研等特殊需要输入禁止入境物的,必须提供( )签发的特许审批证明。
由建设单位通过招标方式选聘物业管理企业的,称为()。
“心理正常”意味着()
毛泽东在《矛盾论》中认为,矛盾问题的精髓是
Themarketinvestigationisindispensabletosalespromotion.Theyarecloselyrelatedasthelipsandteeth,sotospeak.What
Thebrainsofchildrenareaffectedbyfamilyviolenceinthesamewayascombataffectssoldiers,accordingtoastudy.Inbot
最新回复
(
0
)