首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
给定程序MODI1.C是建立一个带头结点的单向链表,并用随机函数为各结点赋值。函数fun的功能是将单向链表结点(不包括头结点)数据域为偶数的值累加起来,并且作为函数值返回。 请改正函数fun中指定部位的错误,使它能得出正确的结果。注意:不要改动ma
给定程序MODI1.C是建立一个带头结点的单向链表,并用随机函数为各结点赋值。函数fun的功能是将单向链表结点(不包括头结点)数据域为偶数的值累加起来,并且作为函数值返回。 请改正函数fun中指定部位的错误,使它能得出正确的结果。注意:不要改动ma
admin
2017-07-27
38
问题
给定程序MODI1.C是建立一个带头结点的单向链表,并用随机函数为各结点赋值。函数fun的功能是将单向链表结点(不包括头结点)数据域为偶数的值累加起来,并且作为函数值返回。
请改正函数fun中指定部位的错误,使它能得出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!
1 #include<stdio.h>
2 #include<stdlib.h>
3 typedef struct aa
4 {int data; struct aa *next;} NODE;
5 int fun(NODE *h)
6 { int sum=0;
7 NODE *p;
8 /**********found**********/
9 p=h;
10 while(p)
11 { if(p->data%2==0)
12 sum+=p->data;
13 /**********found**********/
14 p=h->next;
15 }
16 return sum;
17 }
18 NODE *creatlink(int n)
19 (NODE *h,*p,*s;
20 int i;
21 h=p=(NODE*)malloc(sizeof(NODE));
22 for(i=1;i<=n;i++)
23 {s=(NODE *)malloc(sizeof(NODE));
24 s->data=rand()%16;
25 s->next=p->next;
26 p->next=s;
27 p=p->next;
28 }
29 p->next=NULL;
30 return h;
31 }
32 outlink(NODE *h,FILE *pf)
33 {NODE *p;
34 p=h->next;
35 fprintf(Pf,’’in\nTHE LIST:in\n HEAD’’);
36 while(p)
37 {fprintf(pf,’’->%d’’,p->data); p=p->next;}
38 fprintf(pf,’’in’’);
39 }
40 outresult(int s,FILE *pf)
41 { fprintf(pf,’’\nThe sum of even numbers:%d\n’’,s);}
42 main()
43 { NODE *head;int even;
44 head=creatlink(12);
45 head->data=9000;
46 outlink(head,stdout);
47 even=fun(head);
48 printf(’’\nThe result:in’’); outresult(even,stdout);
49 }
选项
答案
(1)p=h->next; (2)p=p->next;
解析
(1)根据题干中求得除了头结点之外的结点数据域中的数据值,头指针h,工作指针p指向头结点的下一个结点,所以第一个标识下的“p=h;”指向头结点应该改为指向下一个结点“p=h->next;”。
(2)工作指针p,利用p实现对链表的遍历,p表示指向链表的当前结点,所以指向下一个结点应该是“p=p->next;”。
转载请注明原文地址:https://kaotiyun.com/show/HKDp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
有以下程序includemain(){chara[30],b[30];scanf(“%s”,a);gets(b);printf(“%s\n%s\n”,a,b);}程序运行时
以下语句定义正确的是()。
下列字符数组初始化语句中,不正确的是()。
有以下程序#include<stdio.h>intfun(inta,intB){if(b=0)returna;elsereturn(fun(--a,--B));}main(){pdntf("%d\
下面程序的功能是:输出100以内能被3整除且个位数为9的所有整数,清填空。main(){inti,j;for(i=0;();i++){j=i*10+9;if(j%3!=0)continue;print
有以下程序:#include<stdio.h>main(){FILE*fp;inta[10]={1,2,3,0,0},i;fp=fopen("d2.dat","wb");fwrite(a,sizeof(int)
若语句“t=fun(fun(x,y,A),(a+b,a+C),x+y+z);”对fun函数的调用正确,则fun函数的形参个数为()。
以下选项中,当x为大于1的奇数时,值为0的表达式为()。
某二叉树中度为2的节点有18个,则该二叉树中有()个叶子节点。
以下程序的输出结果是【】。#inculde#inculde#inculdemain(){char*P,*q,*r;P=q=r=(char*)malloc(sizeof(char)*20):
随机试题
患者,女,38岁。近两天来无明显诱因出现高热,体检除显著贫血貌外,无特殊阳性体征。实验室检查:外周血象全血细胞减少,网织红细胞明显减少;骨髓象提示骨髓增生低下。该患者最可能的诊断是
A.四环素B.螺旋霉素C.甲硝唑D.青霉素E.交沙霉素下列疾病治疗时,若用抗生素治疗应首选的药物
主要兴奋B受体的拟肾上腺素药是
在下列各项中,医师可以行使特殊的干涉权的是
城市地下铁道岩石的饱和极限抗压强度fr=20MPa,属于()。
证券投资的管理成本包括()
企业持有的—年内到期的长期债券投资应征资产负债表的()项目列示。
南宋词人______在《扬州慢》中有“过春风十里,______”之句,描绘了遭战争洗劫后扬州城的荒芜景象,令人感叹。
幼儿在家中和学校里看到了大量的桌子,掌握了“桌子”的概念,幼儿对于“桌子”这个概念学习的方式是
WhatisitaboutAmericansandfood?Welovetoeat,butwefeel【S1】______aboutitafterward.Wesaywewantonlythebest,but
最新回复
(
0
)