阅读以下说明和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 len;
char as[10] ,rs[20];
printf("[1 ,10000]内的同构数: \r");
for(a=1;a<=10000;a++) {
t = (1) ; /*取整数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 , (2) )==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++] = (3) + '0' ;
num = num/10;
}
s[n]='\0';
for(i=0; i<n/2; i++) { /*将s中的字符串逆置*/
(4) ; 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; (5) );/*使ms指向所得子串的首部字符*/
return ms;
}
正确答案及解析
正确答案
解析
(1)a%10,或其等价形式
(2)right(rs,len)
(3)num%10 ,或其等价形式
(4)ch = s[i],或ch = *(s+i)
(5) i++,ms--,或ms--,i++,或其等价形式
本题考查C语言语法、数据指针和运算逻辑的应用。首先应认真分析题目中的说明,然后确是代码结构和各变量的作用。 根据题目中的叙述,同构数的个位数为1、5 或 6,因此,对于不超过10000的每个整数,应先获取其个位数字,因此空(1)处应填入"a %10"或其等价形式,从而可以先过滤掉不可能是同构数的数。
根据代码中的注释,通过以下运算后,得到由a中数值转换所得的字符串as,以及a的平方所得数值转换得到的字符串rs,此后通过字符串比较运算来判断是否为同构数。
len = myitoa(a ,as); /*数a转换为字符串,存入as*/
myitoa(a*a ,rs); /*数a的平方转换为字符串,存入rs*/
函数myitoa(int num,char划的功能是将整数num转换为字符s,这就需要将整数num的每个数字分离出来,通常通过整除取余运算实现,即以下代码所实现的。
while (num) (/*从个位数开始,取num的每一位数字转换为字符后放入s[] */
s[n++] = (3) + '0';
num = num/10;
}
s[n]='\0';
其中,空(3)处应填入"num%10" 或其等价形式。
函数right(char*ms,int length)取字符串ms尾部长度为lenth的子串,返回所得子串的首字符指针。该函数的处理思路是先技到ms中字符串的结尾,然后倒着数出length个字符,从而得到所需字符串的首字符指计。空(5)处应填入"i++,ms--” 或其等价形式。
另一个更简便的方式是在得到ms的结尾指针后,再减去length即可,即最后返回ms-lenth即可。
你可能感兴趣的试题
一台主机的IP地址为202.123.25.36,掩码为255.255.254.0。如果该主机需要在该网络进行直接广播,那么它应该使用的目的地址为( )
-
- A.202.123.25.0
- B.202.123.25.255
- C.202.123.24.0
- D.202.123.24.255
- 查看答案
在计算机系统的日常维护工作中,应当注意硬盘工作时不能__(2)__。另外,需要防范病毒,而__(3)__是不会被病毒感觉的。
-
- A.电子邮件
- B.硬盘
- C.U盘
- D.ROM
- 查看答案
有 4 个 IP 地址:201.117.15.254、201.117.17.01、201.117.24.5 和 201.117.29.3,如果子网掩码为 255.255.248.0,则这 4 个地址分别属于3个子网;其中属于同一个子网的是()
-
- A.201.117.15.254 和 201.117.17.01
- B.201.117.17.01 和 201.117.24.5
- C.201.117.15.254 和 201.117.29.3
- D.201.117.24.5 和 201.117.29.3
- 查看答案
在异步通信中,每个字符包含1位起始位、7位数据位、1位奇偶位和1位终止位,每秒钟传送200个字符,采用4相位调制,则码元速率为()。
-
- A.50波特
- B.500波特
- C.550波特
- D.1000波特
- 查看答案
在 Windows 中,运行( )命令得到下图所示结果。以下关于该结果的叙述中,错误的是( )。
Pinging 59.74.111.8 with 32 bytes of data:
Reply from 59.74.111.8: bytes=32 time=3ms TTL=60
Reply from 59.74.111.8: bytes=32 time=5ms TTL=60
Reply from 59.74.111.8: bytes=32 time=3ms TTL=60
Reply from 59.74.111.8: bytes=32 time=5ms TTL=60
Ping statistics for 59.74.111.8:
Packets: Sent = 4, Received = 4, Lost = 0 (0% loss),
Approximate round trip times in milli-seconds:
Minimum = 3ms, Maximum = 5ms, Average = 4ms
-
- A.该命令使得本地主机向目标主机发送了 4 个数据包
- B.本地主机成功收到了目标主机返回的 4 个数据包
- C.本地主机与目标主机连接正常
- D.该命令用于查看目标主机的 IP 地址
- 查看答案