首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
下列给定程序中,函数fun的功能是:在带头结点的单向链表中,查找数据域中值为ch的结点。找到后通过函数值返回该结点在链表中所处的顺序号;若不存在值为ch的结点,函数返回0值。 请在程序的下画线处填入正确的内容并将下画线删除,使程序得出正确的结果。 注意:部
下列给定程序中,函数fun的功能是:在带头结点的单向链表中,查找数据域中值为ch的结点。找到后通过函数值返回该结点在链表中所处的顺序号;若不存在值为ch的结点,函数返回0值。 请在程序的下画线处填入正确的内容并将下画线删除,使程序得出正确的结果。 注意:部
admin
2020-10-26
32
问题
下列给定程序中,函数fun的功能是:在带头结点的单向链表中,查找数据域中值为ch的结点。找到后通过函数值返回该结点在链表中所处的顺序号;若不存在值为ch的结点,函数返回0值。
请在程序的下画线处填入正确的内容并将下画线删除,使程序得出正确的结果。
注意:部分源程序给出如下。
不得增行或删行,也不得更改程序的结构!
试题程序:
#include<stdio.h>
#include<stdlib.h>
#define N 8
typedef struer liSt
{ int data;
struct list *next;
}SLIST;
SLIST*creatlist(char*);
void outlist(SLIST*);
int fun(SLIST*h,char ch)
{ SLIST*P; int n=0;
P=h->next ;
/*********found*********/
while(p!=
【1】
)
{ n++;
/*********found*********/
if(P->data==ch)
return
【2】
;
else P=P->next;
}
return 0;
}
main()
{ SLIST*head;int k;char ch;char a[N]={’m’,’p’,’g’,’a’,’w’,’x’,’r’,’d’};
head=creatlist(a);
outliSt(head);
printf("Enter a letter:");
scanf("%c",&ch);
/*********found*********/
k=fun(
【3】
);
if(k==0)
printf("\nNot found!\n");
else
printf("The sequence number is:%d\n",k);
}
SLIST*creatlist(char*a)
{ SLIST*h,*p,*q;int i;
h=p=(SLIST*)malloc(sizeof(SLIST));
for(i=0;i<N;i++)
{ q=(SLIST*)malloc(sizeof(SLIST));
q->data=a
;P->next=q;
p=q;
}
P->next=0;
return h;
}
void outlist(SLIST*h)
{ SLIST*P;
P=h->next;
if(P==NULL)
printf("\nThe list is NULL!\n");
else
{printf("\nHead");
do
{ printf("->%C",
p->data);p=p->next;}
while(P!=NULL);
printf("->End\n"”);
}
}
选项
答案
1)NULL (2)n (3)head,ch
解析
填空1:while循环语句用来判断是否到达链表结尾,链表结尾结点指针域是NULL。
填空2:若找到指定字符,则通过return语句将该结点在链表的顺序号返回给main函数。
填空3:函数调用语句,其形式是:函数名(实际参数表),因此根据函数定义语句,填入head,ch。
转载请注明原文地址:https://jikaoti.com/ti/KGD0FFFM
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
设有如下程序段inta[2]={0};intb[]={0,0,1};charc[]={’’A’’};chard=’’\0’’;以下叙述中正确的是()。
有以下程序:#includemain(){charb[3][10],C;inti;for(i=0;i
有以下程序:#includemain(){inta=2,b;b=(a>>=1)+4;printf("%d,%d",a,b);}程序运行后的输出结果是()。
有以下程序:#ncludemain(){charc;for(;(c=getchar())!=’#’;){if(c>=’a’&&c
以下程序段中,与其他三个功能不同的程序段是()。
有以下程序:#includevoidfun(int,*s,intt,int*k){intp;for(p=0,*k=p;ps[*k])*k=p;}main(){int
关于C语言函数说明的位置,以下叙述正确的是()。
若有定义语句inta,b;doublex;,则下列选项中没有错误的是()。【10年9月】
设有如下类型说明语句typedefstruct{intnum;struct{inty,m,d;}date;}PER;则以下定义结构体数组并赋初值的语句中错误的是()。
随机试题
根据经营单位组合分析法,业务增长率高而且市场占有率低的企业经营业务状况类型是()
伤寒暴发流行的主要原因
小青龙汤是枳实消痞丸是
以下哪项对于治疗陈旧性股骨颈骨折、股骨头缺血性坏死的患者最佳
根据《建设项目工程结算编审规程》的规定,工程价款结算的方式包括()。
某变压器一、二次绕组之比为3,忽略效率损失,如输入电压为330V,其输出电压为()。
北京天坛的主体建筑由圜丘坛、皇穹宇、祈谷坛、斋宫四部分组成,其中专门供奉皇天上帝和皇帝祖先牌位的殿宇是()。
下列哪种记忆类型符合俗语所说的“良言一句三冬暖,恶语伤人恨不休”()
简述春秋时期赋税制度的改革及其影响。
下列选项蕴涵矛盾的同一性的是()
最新回复
(
0
)