首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
给定程序modi1.C的主函数中,将a、b、c三个结点链成一个单向链表,并给各结点的数据域赋值,函数fun()的作用是:累加链表结点数据域中的数据作为函数值返回。 请改正函数fun中指定部位的错误,使它能得出正确的结果。 注意:不要改动ma
给定程序modi1.C的主函数中,将a、b、c三个结点链成一个单向链表,并给各结点的数据域赋值,函数fun()的作用是:累加链表结点数据域中的数据作为函数值返回。 请改正函数fun中指定部位的错误,使它能得出正确的结果。 注意:不要改动ma
admin
2018-09-27
39
问题
给定程序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://jikaoti.com/ti/gAa0FFFM
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
若变量c为char类型,能正确判断出c为小写字母的表达式是()
以下叙述中错误的是______。
若输入000051,下列程序的运行结果为______。main(){unsignedinta;scanf("%o",&a);printf("%o\n",getbits(a));}getbits(value)unsignedint
有如下程序: 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级模式,用来描述数据库中全体数据的全局逻辑结构和特性的是()。
设有定义:char*c;,以下选项中能够使字符型指针c正确指向一个字符串的是()。
下面程序的功能是:计算1~10之间的奇数之和与偶数之和,请填空。#include<stdio.h>main(){inta,b,c,i;a=c=0;for(i=0;i<=10;i+=2)
在数据库设计的四个阶段中,为关系模式选择存取方法应该是在______阶段。
随机试题
下列哪一些属于个体劳动防护用品()。
A.紫绀B.黄染C.色素沉着D.紫癜E.蜘蛛痣由血管破裂引起的是()
冻疮患者一般不出现的皮损是
疾病的标本,实质上反映了疾病的
患者咽中不适,如有物梗阻,咯之不出,咽之不下,胸中窒闷,舌苔白腻,脉弦滑。其证候是
调节红细胞生成的特异性体液因子是
A、淡黄色B、淡红色C、淡绿色D、淡蓝色E、白色;根据《处方管理办法》急诊处方的印刷用纸颜色为
以下关于非居民企业承包工程作业和提供劳务所得采用核定征收办法表述错误的是()。
某上市公司2007年初发行在外的普通股10000万股,2007年3月2日新发行4500万股,12月1日回购1500万股,以备将来奖励职工。该公司2007年实现净利润2725万元。不考虑其他因素,该公司2007年每股收益为()元。
Kitchendutiesmayhavetraditionallybeenviewedaswomen’swork,butnotattheWhiteHouse.Untilnow:CristetaComerfordhas
最新回复
(
0
)