首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
给定程序中,函数fun的功能是将不带头结点的单向链表逆置,即若原链表中从头至尾结点数据域依次为2、4、6、8、10,逆置后,从头至尾结点数据域依次为10、8、6、4、2。 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。
给定程序中,函数fun的功能是将不带头结点的单向链表逆置,即若原链表中从头至尾结点数据域依次为2、4、6、8、10,逆置后,从头至尾结点数据域依次为10、8、6、4、2。 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。
admin
2017-09-23
33
问题
给定程序中,函数fun的功能是将不带头结点的单向链表逆置,即若原链表中从头至尾结点数据域依次为2、4、6、8、10,逆置后,从头至尾结点数据域依次为10、8、6、4、2。
请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。
注意:部分源程序给出如下。
不得增行或删行,也不得更改程序的结构!
试题程序:
#include < stdio.h >
#include < stdlib.h >
#define N 5
typedef struct node{
int data;
struer node* next;
}NODE;
/*********found*********/
【1】
*fun(NODE,lc h)
{ NODE*p,*q,*r;
p=h;
if(P==NULL)
retUrr1 NULL;
q=p一 >next;
p一 >next=NULL;
while(q)
{
/*********found*********/
r=q一 >
【2】
;
q一 >next=p;
P=q;
/*********found*********/
q=
【3】
;
}
return p;
}
NODE*creatlist(int a[])
{ NODE* h,*P,*q;int i;
h=NULL;
for(i=0;i < N;i++)
{ q=(NODE*)malloc(sizeof
(NODE));
q一 >data=a
;
q一 >next=NULL;
if(h==NULL)h=p=q;
else{p一 >next=q;p=q;)
}
return h;
}
void outlist(NODE*h)
{ NODE*p;
p=h;
if(P==NULL)
printf(’The list is NULL!\n");
else
{printf("\nHead");
do
{printf("一 >%d",p一 >
data);
p=p一 >next;}
while(P!=NULL);
printf("一 >End\n");
}
}
main()
{ NODE * head;
int a[N]={2,4,6,8,10);
head=crear1ist(a);
printf("\nThe original
list:\n");
out;list(head);
head=fun(head);
printf("\nThe list after
inverting:\n");
outlist(head);
}
选项
答案
(1)NODE (2)next (3)r
解析
填空1:本题考查了函数指针变量的函数返回值的类型,*fun( NODE *h)的返回值为p,而p的数据类型为NODE,因此本空应该填写NODE。
填空2:从此空的形式p一 >可知本空应该填写next。
填空3:本题要求将不带头结点的单向链表逆置,为了使q的指针向后移,此空应该填写r。
转载请注明原文地址:https://jikaoti.com/ti/Cea0FFFM
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
有以下程序:#include<stdio.h>#defineN8voidfun(int*x,inti){*x=*(x+i)+1;}main(){inta[N]={1,2,3,4,5,6,7,8},i
定义如下变量和数组:inti,x[3][3]={1,2,3,4,5,6,7,8,9};则下面语句的输出结果是()。for(i=0;i<3;i++)printf("%d",x[i][2-i]);
当a=1、b=2、c=3、d=4时,执行下面程序段后,x的值是()。if(a<B)if(c<D)x=1;elseif(a<C)if(b<D)x=2:elsex=3:elsex=6:elsex=7
若有chars[3][3]=={"AAA","BBB","CCC"};说明语句,则与它等价的语句是()。
下面程序的运行结果是()。#include<stdio.h>#include<string.h>main(){char*s1="abDuj";char*s2="ABdUG";intt;t=s
已知字母a的ASCII码为十进制数97,下面程序的输出结果是()。#include<stdio.h>main(){charc1,c2;c1=’a’+’6’-’0’;c2=’a’+’3’-’0’;
当把4个表达式用做if语句的控制表达式时,有一个选项与其他3个选项含义不同,这个选项是()。
若有以下定义和语句:inta=010,b=0×10,c=10;printf("%d,%d,%d\a",a,b,C);则输出结果是()。
已知一个文件中存放若干工人档案记录,其数据结构如下:structa{charnumber[100];intage;floatp[6];};定义一个数组:structanumber[10];
若已定义的函数有返回值,则以下关于该函数调用的叙述中错误的是()。
随机试题
已知红松实体模样质量是4kg,浇出的铸钢件质量是70.8kg,那么用质量为2kg的红松实体模样浇注的铸钢件质量是()kg。
急性肾衰病人的饮食护理,哪项正确()
牙周炎病损确立期的主要病理变化是()
某建筑工程公司委托其业务员甲某外出采购水泥,甲某以该建筑工程公司的名义与乙公司签订了一份钢材购销合同,则下列说法中,不正确的是()。
以下能导致流动负债减少的是()
阅读下列材料,简析两位大师表达的异同。晚年的毕加索为了能够独处,用最后的精力去创作,就把所有的人都拒之千里。他把那些赶来想一睹大师风采的人戏称为“池塘里的青蛙”。一位华裔英籍作家翻译介绍了钱钟书先生的作品,回国时想拜访一下先生,钱先生说
春节将至,如果你所在的公安机关派你运送物资到四川灾区慰问.你如何组织?
反映论是一切唯物主义的认识论的一个基本观点,认为认识是对世界的反映,坚持从物到感觉和思想的认识路线。()
接近权:是处理媒介、公众、政府三者关系的理论,主张大众即社会的每一个成员都有接近、利用媒介发表意见的自由。表现形式有反论权和意见广告。根据上述定义,下列属于接近权的是:
在考生文件夹中有一个工程文件execise32.vbp(相应窗体文件为execise32.frm)。窗体Form1中已经给出了所有控件。其功能是:单击“读入”命令按钮,则把考生目录下的in32.txt文件中的所有英文字符放入Text1(可多行显示):如果
最新回复
(
0
)