首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读以下说明和C函数,填补代码中的空缺(1)~(5),将解答填入答题纸的对应栏内。 【说明】 函数removeDuplicates(char*str)的功能是移除给定字符串中的重复字符,使每种字符仅保留一个,其方法是:对原字符串逐个字符进行扫描,遇
阅读以下说明和C函数,填补代码中的空缺(1)~(5),将解答填入答题纸的对应栏内。 【说明】 函数removeDuplicates(char*str)的功能是移除给定字符串中的重复字符,使每种字符仅保留一个,其方法是:对原字符串逐个字符进行扫描,遇
admin
2016-05-11
52
问题
阅读以下说明和C函数,填补代码中的空缺(1)~(5),将解答填入答题纸的对应栏内。
【说明】
函数removeDuplicates(char*str)的功能是移除给定字符串中的重复字符,使每种字符仅保留一个,其方法是:对原字符串逐个字符进行扫描,遇到重复出现的字符时,设置标志,并将其后的非重复字符前移。例如,若str指向的字符串为“aaabbbbscbsss”,则函数运行后该字符串为“absc”。
【C代码】
void remoVeDuplicates(char*str)
{
int i,len=strlen(str); /*求字符串长度*/
if( (1) )return; /*空串或长度为1的字符串无需处理*/
for(i=0;i<len;i++) {
int flag=0; /*字符是否重复标志*/
int m;
for(m= (2) ;m<len;m++){
if(str
=str[m]){
(3) ; break;
}
}
if(flag) {
int n,idx=m;
/*将字符串第idx字符之后、与str
不同的字符向前移*/
for(n=idx+1;n<len;n++)
if(str[n]!=str
){
str[idx]=str[n]; (4) ;
}
str[ (5) ]=’\0’; /*设置字符串结束标志*/
}
}
}
选项
答案
(1)len<2 或len<=1 或等价表示 (2)i+1 或等价表示 (3)flag=1 或给flag赋值为任何一个不是0的值 (4)idx++ 或idx=idx+1 或等价表示 (5)idx 或等价表示
解析
本题考查C语言基本应用。
题目要求在阅读理解代码说明的前提下完善代码。字符串的运算处理是C程序中常见的基本应用。
根据注释,空(1)处应填入的内容很明确,为“fen←I”或其等价表示。
要消除字符串中的重复字符,需要扫描字符串,这通过下面的代码来实现:
for(i=0;i<len;i++){
int flag=0; /*字符是否重复标志*/
int m;
for(m= (2) ;m<len;m++){
if(str
==str[m]){
(3) ; break;
}
}
上面代码中,循环变量i用于顺序地记下字符串中每个不同字符首次出现的位置,那么后面的处理就是从i的下一个位置开始,考查后面的字符中有没有与它相同的(str
=str[m]),因此空(2)应填入“i+1”或其等价表示。显然,当发现了重复字符时,应设置标志,空(3)处应填入“flag=1”或者给flag赋值为任何一个不是O的值。
根据说明,发现与s仃
相同的第一个字符str[m]后,需要将其后所有与str
不同的字符前移,以覆盖重复字符str[m],对应的代码如下:
if (flag ) {
int n, idx=m;
/*将字符串第idx字符之后、与str
不同的字符向前移*/
for( n=idx+l; n<len; n++ )
if( str[n]!=str
) {
str[idx] =str[n]; (4) ;
}
str[ (5) ]=’\0’; /*设置字符串结束标志*/
}
初始时,idx等于m,使str[n]覆盖str[idx]后,需要将idx自增,以便将后面与str
不同的字符继续前移,因此空(4)处应填入“idx++”或等价表示。由于后面字符前移了,所以字符串结束标志也需重新设置,空(5)处应填入“idx”。
转载请注明原文地址:https://kaotiyun.com/show/j9jZ777K
本试题收录于:
程序员下午应用技术考试题库软考初级分类
0
程序员下午应用技术考试
软考初级
相关试题推荐
图文混排是Word的特色功能之一,下列叙述中,不正确的是(46)。
假设100个数据的平均值为82.31,其中有10个数据又发生了如下增减变化:+3.52,+2.87,-4.13,+5.34,-2.87,+2.50,-3.52,+4.23,-5.04,+0.10,则新的平均值变为(26)。
在统计学中,用来衡量一个样本中各个数据波动大小的量是______。
小张刚接到领导分配的数据分析任务,他第一步应当首先________。
某信息处理技术员正在做大批数据处理的大项目时,领导又交宋了另一项临时性的紧迫工作,要求优先处理。该信息处理技术员需要转而做新的工作,他对原工作的处理方式应该是(69)。
为将演示文稿置于另一台不带PowerPoint系统的计算机上放映,那么在放映前应该对演示文稿进行()。
Make()copiesofimportantfiles,andstorethemonseparatelocationstoprotectyourinformation.
在Access中,查询“学生”数据表的所有记录及字段的SQL语句是______。
在PowerPoint中单击快捷功能按钮(61)可以新建一个演示文稿。
阅读以下说明,回答问题1至问题4。说明某公司A楼高40层,每层高3.3米,同一楼层内任意两个房间最远传输距离不超过90米,A楼和B楼之间距离为500米,需在整个大楼进行综合布线,结构如图1-1所示。为满足公司业务发展的需要,要求为楼内客户机提供数
随机试题
高速公路行车紧急情况避险的处理原则是什么?
在有氧条件下乳酸钠需转化为HCO3而起作用,进行转化的部位为
A.在盐酸条件下用溴酸钾滴定液滴定B.在盐酸条件下用亚硝酸钠滴定液滴定C.在醋酐中用高氯酸滴定液滴定D.在254nm处测定供试品溶液的吸光度E.在306nm处测定供试品溶液的吸光度以下药物的含量测定,《中国药典》所采用的方法是盐酸氯丙嗪注射液
商品的价值量是由生产该商品的( )决定的。
饰面砖粘贴工程一般适用于内墙饰面砖粘贴工程和高度不大于100m、抗震设防烈度不大于8度、采用()施工的外墙饰面砖粘贴工程。
我国颁布的第一个现代学制是()。
我国北方多煤、铁、石油等资源,南方多有色金属。()
某操作系统的文件管理采用直接索引和多级索引混合方式,文件索引表共有10项,其中前8项是直接索引项,第9项是一次间接索引项,第10项是二次间接索引项,假定物理块的大小是2KB,每个索引项占用4B,试问:假定一个文件的实际大小是128MB,该文件实际占用磁
法律意识的作用主要表现为()。
Youwillhearfiveshortpieces.Foreachpiecedecidewherethespeakeris.Writeoneletter(A-H)nexttothenumberofthepiec
最新回复
(
0
)