当前位置: 首页icon 51CTO软考 > 软考资讯 >考试科目 >2018年11月程序员考前模拟下午题(二)之二

2018年11月程序员考前模拟下午题(二)之二

作者:wx611cbc2c011022023-11-14 01:00:15
备考咨询 刷题指导
添加专属学姐
下载资料 2024上半年软考备考资料+考试大纲
下载按钮 下载
引号

摘要:对于【程序员】软考考试而言,试题无疑是最重要的学习资料之一。在软考备考过程中,吃透试题、掌握试题所考知识点、熟悉试题的出题思路,对我们提升分数的效果是最明显的,通过对试题的反复练习,还可以查漏补缺。今天,给大家带来【2018年11月程序员考前模拟下午题(二)】部分试题的详解,一起来看看吧~1、阅读下列说明和图,回答问题,将解答填入答题纸的对应栏内。阅读以下说明和C函数,

引号
摘要:对于【程序员】软考考试而言,试题无疑是最重要的学习资料之一。在软考备考过程中,吃透试题、掌握试题所考知识点、熟悉试题的出题思路,对我们提升分数的效果是最明显的,通过对试题的反复练习,还可以查漏补缺。今天,给大家带来【2018年11月程序员考前模拟下午题(二)】部分试题的详解,一起来看看吧~



1、阅读下列说明和图,回答问题,将解答填入答题纸的对应栏内。阅读以下说明和C函数,将应填入 (n) 处的语句或语句成分写在答题纸的对应栏内。【说明1】函数deldigit(char *s) 的功能是将字符串s中的数字字符去掉,使剩余字符按原次序构成一个新串,并保存在原串空间中。其思路是:先申请一个与s等长的临时字符串空间并令t指向它,将非数字字符按次序暂存入该空间,最后再拷贝给s。【C函数】char *t = (char *)malloc(   (1)   ); 
/*申请串空间*/

  int i, k = 0;

  

  if (!t)  return;

  for(i = 0; i < strlen(s); i++)

if ( !(*(s+i)>=’0’ && *(s+i)<=’9’) ) {

    t[k++] =   (2)  ;

}

    (3)   = ’\0’;          /*设置串结束标志*/

  strcpy(s,t);

free(t);

}【说明2】函数reverse(char *s, int len)的功能是用递归方式逆置长度为len的字符串s。例如,若串s的内容为"abcd",则逆置后其内容变为"dcba"。【C函数】void reverse(char *s, int len)

{

  char ch;

  if (   (4)   )

  {

    ch = *s;

    *s = *(s+len-1);

    *(s+len-1) = ch;

    reverse(   (5)   );

  }

}
答案:

(1)strlen(s)+1
(2)*(s+i),或s[i]或其等价表示
(3)*(t+k)或t[k] 或其等价表示
(4)len>1  或len>=1  或其等价表示
(5)s+1  len-2


答题解析:

根据说明1,在函数deldigit(char*s)中需先申请一个与s等长的临时字符串空间并令t指向它,因此空(1)处应填入"strlen(s)+1",其中,加1的原因是函数strlen计算s所指向字符串的长度时,没有包含串结束标志字符"\0"。当然,申请比"strlen(s)+1"更大的存储区也可以,只是没有必要。
由于需要将非数字字符按原来的顺序存入t所指向的存储区,所以空(2)处填入"s[i]",或其等价表示形式。
最后在设置t所指向字符串的结束标志,即令t[k]='\0'.在这里,空(3)处的t[k]写为t[k++]也可以,而写为t[k+1]或t[++k]则不符合整个代码的处理逻辑。
函数reverse(char*s,int len)的功能是用递归方式逆置长度为len的字符串s,其中以下代码实现了将s所指字符与串中最后一个字符交换的处理。
Ch=*s; *s=*(s+len-1); *(s+len-1)=ch;



查看完整试题>>>


免费刷题报考资讯 机考模拟 学习群