首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
下列给定程序是建立一个带头结点的单向链表,并用随机函数为各结点赋值。函数fun()的功能是:将单向链表结点(不包括头结点)数据域为偶数的值累加起来,并作为函数值返回。 其累加和通过函数值返回main()函数。例如,若n=5,则应输出8.391667。
下列给定程序是建立一个带头结点的单向链表,并用随机函数为各结点赋值。函数fun()的功能是:将单向链表结点(不包括头结点)数据域为偶数的值累加起来,并作为函数值返回。 其累加和通过函数值返回main()函数。例如,若n=5,则应输出8.391667。
admin
2013-06-12
74
问题
下列给定程序是建立一个带头结点的单向链表,并用随机函数为各结点赋值。函数fun()的功能是:将单向链表结点(不包括头结点)数据域为偶数的值累加起来,并作为函数值返回。
其累加和通过函数值返回main()函数。例如,若n=5,则应输出8.391667。
请改正程序中的错误,使它能得到正确结果。
[注意] 不要改动main函数,不得增行或删行,也不得更改程序的结构。
[试题源程序]
#include<stdio.h>
#include<stdiib.h>
typedef struct aa
{
int data;
struct aa *next;
}NODE;
int fun(NODE *h)
{
int sum=0;
NODE *P;
/**********found**********/
p=h;
while(P->next)
{
if(p->data%2==0)
sum+=p->data;
/**********found**********/
p=h->next;
}
return sum;
}
NODE *creatlink(int n)
{
NODE *h, *p, *s, *q;
int i, x;
h=p=(NODE *)malloc(si zeof(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, "\n\nTHE LIST:\n\n HEAD");
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 : %d\n", 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);
}
选项
答案
(1)错误:while(p->next) 正确:while(p!=NULL)或while(p) (2)错误:p=h->next; 正确:p=p->next;
解析
错误1:循环时要注意循环中止的条件是p!=NULL(最后一个结点为空,就像字符串的最后一个字符为结尾标志符’\0’一样),while(p->next)使循环提前结束,所以应改为while(p!=NULL)或while(p)。
错误2:当累加完后,应该把指针指向下一个结点的指针赋给p,而不是把头指针指向的下一个结点赋给p,否则还会造成死循环,所以p=h->next;应该改为p=p->next;。
转载请注明原文地址:https://kaotiyun.com/show/GrJp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
数据流的类型有______和事务型。
数据模型按不同的应用层次分为三种类型,它们是______数据模型、逻辑数据模型和物理数据模型。
有以下程序 main() { int a[3][2]={0},(*pb)[2],i,j; for(i=0;i<2;i++) { ptr=a+i; scanf("%d",ptr);ptr++; } for(i=0;i<3;i++) { for(j=0; j<
以下程序的输出结果是______。 main() { int i, x[3][3]={9,8,7,6,5,4,3,2,1},*p=&x[1][1]; for(i=0;i<4;i+=2)printf("%d",p[i]); }
有以下程序 main() { int x[]={1,3,5,7,2,4,6,0),i,j,k; for (i=o; i<3; i++) for(j=2;j>=i;j--) if(x[j+1]>x[j]){k=x[j]; x[j]=x(j+1); x[j+1
软件工程研究的内容主要包括:______技术和软件工程管理。
给定程序MODI1.C中函数Creatlink的功能是创建带头结点的单向链表,并为各结点数据赋0~m-1的值。#include<Stdio.h>#include<conio.h>#include<stdlib.h>typed
以下与函数fseek(fp,OL,SEEK_SET)有相同作用的是______。
数据的存储结构包括顺序、______、索引和散列四种基本类型。
下列程序是处理C盘根目录下的a.txt文件,统计该文件中字符的个数。请填空,使程序完整。#include<stdio.h>main(){FILE*fp;charch;longnum=0;if
随机试题
下列各项中,属于盈余公积金用途的有()。
李某是13岁的孤女,流落到M地。人贩子杨某看见李某长得五官端正,就把李某收留,准备养到14岁卖一笔好价钱。不料养了一年多后,与李某产生了真挚的父女感情,就不准备卖李某了。则李某的行为属于()
A.聚乙二醇(PEG)B.葡萄球菌A蛋白C.抗体包被试管D.第二抗体E.活性炭属于固相分离法是
CR成像中将光信号转换为电压信号的是
下列关于绩效考核的说法错误的是()。
在采用债务法进行所得税会计处理时,本期转回的前期确认的递延所得税负债,会导致本期所得税费用增加。( )
某企业2012年3月31日,乙存货的实际成本为100万元,加工该存货至完工产成品估计还将发生成本为20万元,估计销售费用和相关税费为2万元,估计用该存货生产的产成品售价110万元。假定乙存货月初“存货跌价准备”科目余额为0,2012年3月31日应计提的存货
Doctorsalreadyknowthatpeoplewhosmokecandamagetheirhearing.ThelateststudyinthejournalTobaccoControl,【C1】_______
在设计测试用例时,主要需要研究(34)。
—WasthedrivingpleasantwhenyouvacationedinCanadalastsummer?—No,it______formanydayswhenwearrived,sotheroadswe
最新回复
(
0
)