刷题刷出新高度,偷偷领先!偷偷领先!偷偷领先! 关注我们,悄悄成为最优秀的自己!

简答题

 

阅读以下说明和C程序,填充程序中的空缺,将解答填入答题纸的对应栏内。

[说明]
正整数n若是其平方数的尾部,则称n为同构数。例如,6是其平方数36的尾部,76是其平方数5776的尾部,6与76都是同构数。下面的程序求解不超过10000的所有同构数。
已知一位的同构数有三个:1,5,6,因此二位同构数的个位数字只可能是1,5,6这三个数字。依此类推,更高位数同构数的个位数字也只可能是1,5,6这三个数字。
下面程序的处理思路是:对不超过10000的每一个整数a,判断其个位数字,若为1、5或6,则将a转换为字符串as,然后对a进行平方运算,并截取其尾部与as长度相等的若干字符形成字符串后与as比较,根据它们相等与否来断定a是否为同构数。

[C程序]
    #include<stdio.h>
    #include<stdlib.h>
    #include<string.h>
    int myitoa(int,char*);    /*将整数转换为字符串*/
    /*right取得指定字符串尾部长度为length的子串,返回所得孔串的首字符指针*/
    char*right(char*,int length);
    int main()
    {
    int a,t;    int fen;
    char as[10],rs[20];
    printf("[1,10000]内的同构数:\n");
    for(a=1; a<=10000;a++)    {
    t=______;   /*取整数a的个位数字*/
    if(t!=1&&t!=5&&t!=6)continue;
    len=myitoa(a,as);    /*数a转换为字符串,存入as*/
    myitoa(a*a,rs);    /*数a的平方转换为字符串,存入rs*/
    /*比较字符串as与rs末尾长度为len的子串是否相等*/
    if(strcmp(as,______)==0)    /*若相同则是同构数并输出*/
    printf("%s的平方为%s\n",as,rs);
    }
    return 0;
    }
    int myitoa(int num,char*s)    /*将整数num转换为字符串存入s*/
    {
    int i,n=0;
    char ch;
    /*从个位数开始,取num的每一位数字转换为字符后放入s[]*/
    while(num){
    s[n++]=______+'0';
    num=num/10;
    }
    s[n]='\0';
    for(i=0; i<n/2;i++){    /*将S中的字符串逆置*/
    ______;s[i]=s[n-i-1]; s[n-i-1]=ch;
    }
    return n;    /*返回输入参数num的位数*/
    }
    char*right(char*ms,int length)
    /*取字符串ms尾部长度为length的孔串,返回所得孔串的首字符指针*/
    {
    int i;
    for(;*ms;ms++);    /*使ms到达原字符串的尾部*/
    for(i=0;i<length;______);    /*使ms指向所得孔串的首部字符*/
    return ms;
    }


使用微信搜索喵呜刷题,轻松应对考试!

答案:

 

 

a%10,或其等价形式
right(rs,len)
num%10,或其等价形式
ch=s[i],或ch=*(s+i)
i++,ms--,或ms--,i++,或其等价形式

 


解析:

这道题目主要考察了C语言的指针操作、字符串处理以及算法逻辑。根据题目的描述和程序的结构,我们可以分析出每个空应该填入什么内容。

对于第一个空,我们需要获取整数a的个位数字,所以应该使用取余运算来获取个位数,即填入(a%10)或其等价形式。在C语言中,%是取余运算符,可以用于获取一个数的个位数字。例如,如果a是两位数,那么a%10就可以得到其个位数字。

第二个空需要比较字符串as与rs末尾长度为len的子串是否相等,所以需要调用right函数获取长度为len的子串进行比较。函数right的实现是将字符串指针ms向后移动len个字符长度,返回新的字符串指针,即返回子串的首字符指针。因此这里应填入right(rs,len)。

第三个空是在myitoa函数中,需要将整数num的每一位数字转换为字符后放入字符串s中。我们可以通过取余操作获取到num的每一位数字,然后将这个数字转换为字符并添加到字符串s中。因此这里应填入(num%10)或其等价形式。例如,如果num是两位数,那么num%10就可以得到其个位数字,然后将其转换为字符并添加到字符串s中。

第四个空是在myitoa函数中,需要将字符串s中的字符进行逆置。这里可以使用指针操作来实现字符串的逆置。我们可以通过交换首尾字符的位置来实现逆置。所以这里应该填入ch=s[i](或 ch=(s+i))。例如,假设s是一个字符数组,"s[i]“表示数组的第i个元素,”(s+i)"表示指向数组第i个元素的指针所指向的值。通过交换这两个位置的字符,可以实现字符串的逆置。注意这里需要将交换前后的字符暂存到变量ch中。

最后一个空是在right函数中,我们需要让指针ms指向所得子串的首部字符的位置。一种简单的方式是直接将指针ms向后移动length个字符长度即可。因此这里应填入i++(或 ms–)或其等价形式等。具体的实现方式取决于编程习惯和代码风格。例如,"ms–"表示将指针ms向后移动一个字符长度,"i++"表示将变量i的值加1等。另外也可以考虑直接计算新的位置并赋值给指针ms,例如ms-(或 length)。

创作类型:
原创

本文链接: 阅读以下说明和C程序,填充程序中的空缺,将解答填入答题纸的对应栏内。[说明]正整数n若是其平方数的

版权声明:本站点所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明文章出处。

让学习像火箭一样快速,微信扫码,获取考试解析、体验刷题服务,开启你的学习加速器!

分享考题
share