首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读以下函数说明和C语言函数,将应填入(n)处的字句写在对应栏内。 【说明】 本题中的函数encode()和decode()分别实现对字符串的变换和复原。其中变换函数encode()顺序考查已知字符串的字符,按以下规则逐组生成新字符串:
阅读以下函数说明和C语言函数,将应填入(n)处的字句写在对应栏内。 【说明】 本题中的函数encode()和decode()分别实现对字符串的变换和复原。其中变换函数encode()顺序考查已知字符串的字符,按以下规则逐组生成新字符串:
admin
2010-01-15
54
问题
阅读以下函数说明和C语言函数,将应填入(n)处的字句写在对应栏内。
【说明】
本题中的函数encode()和decode()分别实现对字符串的变换和复原。其中变换函数encode()顺序考查已知字符串的字符,按以下规则逐组生成新字符串:
(1)若已知字符串的当前字符不是数字字符,则将该字符复制在新字符串中。
(2)若已知字符串的当前字符是一个数字字符,且它之后没有后继字符,则简单地将它复制到新字符串中。
(3)若已知字符串的当前字符是一个数字字符,并且还有后继字符,设该数字字符的面值为n,则将它的后继字符(包括后继字符是一个数字字符)重复复制n+1次到新字符串中。
(4)以上述一次变换为一组,在不同组之间另插入一个下划线“_”用于分隔。例如,encode()函数对字符串26a3t2的变换结果为666_a_tttt_2。
复原函数decode()做与变换函数encode()相反的工作。即复制不连续相同的单个字符,而将一组连续相同的字符(不超过10个)变换成一个用于表示重复次数的数字符和一个重复出现的字符,并在复原过程中略过变换函数,为不同组之间添加的一个下划线字符。
假定调用变换函数encode()时的已知字符串中不含下划线字符。
【函数】
int encode(char *instr, char *outstr){
char *ip, *op, c; int k,n;
ip=instr; op=outstr;
while(*ip){
if(*ip>=’0’ && *ip<=’9’ && *(ip+1)){
n=(1);
c=(2);
for(k=0; k<n;k++)
*op++=c;
}
else (3);
*op++=’_’;
ip++;
}
if(op>outstr)op--;
(4);
return op-outstr;
}
int decode(char *instr, char *outstr){
char *ip, *op, c; int n;
ip=instr; op=outstr;
while(*ip){
c=*ip; n=0;
while(*ip==c&&n<10){
ip++; n++;
}
if((5))*op++=’0’+n-1;
*op++=c;
if((6))ip++;
}
*op=’\0’;
return op-outstr;
}
选项
答案
(1)*ip-’0’+1 (2)*++ip (3)*op++=*ip (4)*op=’\0’ (5)n>1 (6)*ip==’_’
解析
本题考查C语言对字符串的处理。
本题对字符串按一定要求进行编码解码,所以编码规则至关重要。在做题前一定要看清规则,并按规则对程序说明中所举的例子进行手动的编码解码工作。必要时,可以将其和程序比较着看。
下面我们来开始分析程序。
int encode(char *instr, char *outstr){
char *ip, *op, c; int k, n;
ip=instr; op=outstr;
while(*ip){
if(*ip>=’0’ && *ip<=’9’ && *(ip+1)){
上面的if条件表明,只有当*ip为数字,且其下一个字符不为空时执行下面的程序段。也就是说,这是编码规则(3)的处理代码。
n=(1);
c=(2);
从下面的循环结合编码规则(3)的“设该数字字符的面值为n,则将它的后继字符 (包括后继字符是一个数字字符)重复复制n+1次到新字符串中”,可以看出这里的n应是ip所指数字加1,又因为ip指示的是字符型数据,所以(1)空应填*ip-’0’+1。c应是ip+1所指示的字符,又因为此段程序中只有一个ip++语句,但这里的操作相当于对两个字符进行了编码,ip要向后跳两个空间,所以(2)空应填*++ip。
for(k=0;k<n;k++)
*op++=c;
}
else (3);
这里对应规则(1)和(2)直接把字符拷贝到新串。所以(3)空应填*op++=*ip。
*op++=’_’;
ip++;
}
if(op>outstr)op--;
(4);
这里应是给新串outstr加上字符串结束符’\0’。因为如果执行了上面的while循环,则会把字符串26a3t2变换结果为666_a_tttt_2_,而不是程序说明中的666_a_tttt_2。因为上面的while循环中有“while(..)(...*op++=’_’;ip++;}”。所以要把最后一个’_’用字符串结束符’\0’替换掉,刚好“if(op>outstr)op--;”把op指针定位到了最后的’_’。所以(4)空应填*op=’\0’。这里要注意一点,“if(op>outstr)op--”不能直接写成op--。因为当输入串instr为空时,outstr也为空,while()不作处理,则op=outstr。这种情况下,直接把’\0’写到*outstr,表示outstr是一个空串。
return op-outstr;
}
接下来我们分析解码程序decode()。
int decode(char *instr, char *outstr){
char *ip, *op, c; int n;
ip=instr; op=outstr;
while(*ip){
c=*ip;n=0;
while(*ip==c&&n<10){
ip++; n++;
}
上面的循环用于统计字符c的个数。
if((5))*op++=’0’+n-1;
此处把统计个数存到输出串,则表示当前情况符合编码规则(3)。所以(5)空应填n>1。
*op++=c;
if((6))ip++;
因为解码规则中有“并在复原过程中略过变换函数,为不同组之间添加的一个下划线字符”。所以(6)空应填*ip==’_’。
转载请注明原文地址:https://kaotiyun.com/show/iIjZ777K
本试题收录于:
程序员下午应用技术考试题库软考初级分类
0
程序员下午应用技术考试
软考初级
相关试题推荐
操作系统的资源管理功能不包括________________。
计算机操作系统的主要功能是______。
在Excel2003中,A1到E6单元格的值如下图所示,若在A7单元格中输入计算众数的函数“=MODE(A1:E6)”,按回车键后,则.A7单元格显示的值为(47)。
在Microsoft Word中点击“文件”→“另存为”,在保存类型下拉框中不能选择的有(45)。
某金融企业正在开发移动终端非现场办公业务,为控制数据安全风险,采取的数据安全措施中并不包括______。
数据录入工作有两个指标:录入速度和错误率。一般而言,数据录入员在录入大批数据时,录入速度会(65),错误率会(66)。66
在Windows7中,若删除桌面上某个应用程序的快捷方式图标,则(31)。
为了测量航天员每分钟的心跳次数,甲建议测量2分钟的心跳次数再除以2,乙建议测量10秒钟的心跳次数再乘以6,两者相比______。
综合布线系统由6个子系统组成,将图1-1中(1)~(6)处空缺子系统的名称填写在答题纸对应的解答栏内。制作交叉双绞线(一端按EIA/TIA568A线序,另一端按EIA/TIA568B线序)时,其中一端的线序如图1-2(a)所示,另一端线序如图1—2
某计算机字长16位,若采用定点补码整数表示数值,最高1位为符号位,其他15位为数值部分,则所能表示的最小整数为(8),最大负数为(9)。
随机试题
患者鼻衄,头痛,目眩,耳呜,烦躁易怒,两目红赤,口苦,舌红,脉弦数。治宜选用
角膜损伤后可再生的结构是
末次月经第—天是2013年10月27日,其预产期是()
下列属于静态评价指标的是( )。
下列有关缺陷责任的说法中,表述正确的是()。
关于技术档案的说法,不正确的是()。
以下各项中,()是对进口废物管理正确的表述。
某公司成立于2015年1月1日。2015年实现的净利润为1000万元,分配现金股利550万元,提取盈余公积450万元(所提盈余公积均已指定用途);2016年实现的净利润为900万元;2017年计划增加投资,所需资本为700万元。假定公司目标资本结构为自有资
军警不分,警政合一是古代警察的特点之一。()
4416,1404,2816,3515,()
最新回复
(
0
)