1.程序填空
给定程序的功能是将十进制正整数m转换成k进制(2≤k≤9)数的数字输出。例如,
若输入8和2,则应输出1000(即十进制数8转换成二进制表示是1000)。
请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。
注意:不得增行或删行,也不得更改程序的结构!
试题程序:
#include<stdio.h>
Void fun(int m,int k)
{
im aa[20],i;
for(i=0;m;i++){
aa[i]。_l_;
m/=_2_;
}
for(;i;i--)printf("%d",-3-[i-1]);
}
main()。
{
int b,n;
printf("\nPlease enter a number and a base:\n");
scanf("%d%d",&n,&b);
fun(n'b);
}
【答案】
(1)m%k
(2)k
(3)aa
【评析】
(1)此语句是将十进制的整型数据m转换为k进制数据时,将余数保存在数组aa中。
(2)此语句是将十进制的整型数据m转换为k进制数据时,每除一次k后,把商重新赋值给正整数m,以便重复取余。
(3)在for循环之后,i即为转换成的k进制数的位数,所以根据题意要求,此语句应该是:"print("%d", aa[i-l]);"
2.程序修改
给定程序modi.c中,函数fun的功能是:将s所指字符串中最后一次出现的、tl所指子串替换成t2所指子串,所形成的新串放在w所指的数组中。在此处,要求tl和t2所指字符串的长度相同。例如,当s所指字符串中的内容为: "abcdabfabc",t1所指子串中的内容为:
"ab",t2所指子串中的内容为:"99"时,结果,在w所指的数组中的内容应为:
"abcdabf99c"。
请改正程序中的错误,使它能得出正确结果。
注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!
试题程序:
#include<conio.h>
#include<stdio.h>
#include<string.h>
int fun(char*s,char*t1,char*t2,char*w)
{int i;char*p,*r,*a;
strcpy(w,s);
while(w)
(p=w;r=tl;
while(*r)
IF(*r=*p) {r++;p++;}
else break;
if(*r=:=`\0`)a=w;
w++:
}
r=t2;
while(*r){*a芦*r;a++;r++;)
)
main()
{
char s[100],t1[100],t2[100],w[100];
clrscr();
printf("\nPlease enter string S:");scanf("%s",s);
printf("\nPlease enter substring t1:");scanf("%s",t1);
printf("\nPlease entei substring t2:");scanf("%s",t2);
if(strlen(t1)==strlen(t2))
{fun(s,t1,t2,w);
printf("\nThe resuk is:%s\n",w);
}
else printf("\nError:strlen(t1)!=strlen(t2)\n");
}
【答案】
(1)错误:第7行while(w)
正确:while(*w)
(2)错误:第11行 IF(*r==*p) {r++;p++;}
正确:if(*r==*p) {r++;p++;}
【评析】
第7行:题意中要求对这个地址所指向的内容进行判断,所以须在地址前加上+,源程序"while(w)"应改为"while(*w)"或相同作用的语句。
第11行:c语言中,大小写的字母含意不同。源程序中"IF(*r==*p)"是错误的,"IF"应为小写,程序应改为"if(*r==*p)"或相同作用的语句。
3.程序设计
请编写函数fun,函数的功能是:将所有大于1小于整数m的非素数存入xx所指数组中,非素数的个数通过k传回。例如,若输入:17,则应输出:9和4 6 8 9 10 12 14 15 16。
注意:请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
试题程序:
#include<conio.h>
#include<stdio.h>
Void fun(int m,int*k,int xx[])
{
}
main()
void fun(int m,int*k,int xx[])
{ int I,j;*k=0;
for(i=2;i<m;i++)
{ for(j=2;j<I;j++)/*判断i是否能被比它小的整数整除*/
if(i0/oj=:0)break; 。,= '
if(j<i){xX[*k]=i;*k=*k+l;}/*假如i能被整除即为非素数,则将i存Xxx数组中,计数变量k加l*/
}
}
【评析】
非素数的判断方法与素数的判断方法正好相反,它除了能被1和自身整除外,还可被其它的数整除。用求余的方法来判断整除。