题目详情

阅读以下说明和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++,或其等价形式

你可能感兴趣的试题

单选题

高级系统分析师,专项练习,软件水平考试《高级系统分析师》押题

  • A.V(S2)和P(S4)
  • B.P(S2)和V(S4)
  • C.P(S2)和P(S4)
  • D.V(S2)和V(S4)
查看答案
单选题

高级系统分析师,专项练习,软件水平考试《高级系统分析师》押题

  • A.V(S1)P(S2)和V(S3)
  • B.P(S1)V(S2)和V(S3)
  • C.V(S1)V(S2)和V(S3)
  • D.P(S1)P(S2)和V(S3)
查看答案
单选题

高级系统分析师,专项练习,软件水平考试《高级系统分析师》押题

  • A.P(S4)和V(S4)V(S5)
  • B.V(S5)和P(S4)P(S5)
  • C.V(S3)和V(S4)V(S5)
  • D.P(S3)和P(S4)V(P5)
查看答案
单选题

高级系统分析师,专项练习,软件水平考试《高级系统分析师》押题

  • A.P(S3)和V(S4)V(S5)
  • B.V(S3)和P(S4)P(S5)
  • C.P(S3)和P(S4)P(S5)
  • D.V(S3)和V(S4)V(S5)
查看答案
单选题

高级系统分析师,专项练习,软件水平考试《高级系统分析师》押题

  • A.P(S2)和P(S4)
  • B.P(S2)和V(S4)
  • C.V(S2)和P(S4)
  • D.V(S2)和V(S4)
查看答案

相关题库更多 +