首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
下列给定程序中,函数fun的功能是:在带头结点的单向链表中,查找数据域中值为ch的结点。找到后通过函数值返回该结点在链表中所处的顺序号;若不存在值为ch的结点,函数返回0值。 请在下画线处填入正确的内容并将下画线删除,使程序得出正确的结果。 注意:不得增行
下列给定程序中,函数fun的功能是:在带头结点的单向链表中,查找数据域中值为ch的结点。找到后通过函数值返回该结点在链表中所处的顺序号;若不存在值为ch的结点,函数返回0值。 请在下画线处填入正确的内容并将下画线删除,使程序得出正确的结果。 注意:不得增行
admin
2019-04-14
39
问题
下列给定程序中,函数fun的功能是:在带头结点的单向链表中,查找数据域中值为ch的结点。找到后通过函数值返回该结点在链表中所处的顺序号;若不存在值为ch的结点,函数返回0值。
请在下画线处填入正确的内容并将下画线删除,使程序得出正确的结果。
注意:不得增行或删行,也不得更改程序的结构!
试题程序:
#include<stdio.h>
#include<stdlib.h>
#define N 8
typedef struct 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+ +;
if(p—>data= =ch)
/* * * * * * found * * * * * */
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);
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
解析
本题考查:链表相关知识;while循环语句;函数返回值。
填空1:while循环语句判断是否到达链表结尾,链表结尾结点指针域是NuLL。
填空2:若找到指定字符,则通过return语句将该结点在链表的顺序号返回给main函数。
填空3:函数调用语句,其形式是:函数名(实际参数表),因此根据函数定义语句,填入:head,ch。
转载请注明原文地址:https://kaotiyun.com/show/C2Rp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
有以下程序 main(int argc,char *argv[]) { int n=0,i; for(i=1;i<argc;i++) n=n*10+ *argv[i] ’0’; printf("%d\n",n); }
若有下列说明,则()不是对strcpy库函数的正确的调用。strcpy库函数用于复制一个字符串:char*str1="abed",str2[10],*str3="hijklmn",*str4[2],*str5="aaaa";
若有如下程序:main(){staticchar*a[3]={"123","456","789");char**b;b=a;++b;printf("%s,%s\n",*a,*a+1);printf(
以下程序的输出结果是______。main(){inta[4][4]={{1,3,5},{2,4,6},{3,5,7}};printf("%d%d%d%d\n",a[0][3],a[1][2],a[2][1];a
下面程序的运行结果是______。main(){unsigneda=3,b=10;printf("%d\n",a<<2|b>>1);}
有以下程序#include<string.h>main(){charp[]={’a’,’b’,’c’},q[10]={’a’,’b’,’c’};printf("%d%d\n",strlen(p),strlen(q));}
对下述程序的判断中,正确的是()。#include<stdio.h>voidmain(){char*P,s[256];p=s;while(strcmp(s,"theend")){printf("
有以下程序:main(){inti;for(i=0;i<3;i++)switch(i){case0:prinft("%d",i);Case2:prinft("%d",i);def
随机试题
甲型强心苷苷元由多少个碳原子组成
A病邪易感性B发病性质类型C影响病势进退D影响病程长短E决定证候类型体质对疾病的影响表现为
关于施工项目分部工程质量验收的说法,正确的有()。
某实业有限责任公司被甲县国税局处以4500元罚款,该公司不服,于2007年8月4日依法向乙市国税局(位于该市丙区)申请复议,乙市国税局于9月18日作出维持原处罚的复议决定。该公司仍不服,分别向丙区人民法院和甲县人民法院提起行政诉讼。丙区人民法院于9月23日
下列各项中,应作为现金流量表中经营活动产生的现金流量的有()。
只有在最终产品市场稳定的情况下,才适合采用变动成本加固定费转移价格作为企业两个部门(投资中心)之间的内部转移价格。( )
嘉奖有突出成就和重大贡献的单位和人员可用命令。()
下图为典型的复位电路,针对该复位电路,下列描述错误的是(32)________。
文件系统的功能有Ⅰ.统一管理文件存储空间Ⅱ.确定文件信息存放位置及存放形式Ⅲ.实现文件信息的共享Ⅳ.实现文件从名字空间到外存地址的映射
在中国悠久的历史长河中,出现了一些极其重要的发明,指南针(compass)是其中最重要的发明之一。根据古书记载,远古的人们在生产和斗争中利用天然磁体来指示方向。在战国时期(theWarringStatesPeriod)出现了最早的指南针——司南[si
最新回复
(
0
)