填空題
請補(bǔ)充fun函數(shù),該函數(shù)的功能是求不超過給定自然數(shù)的各偶數(shù)之和。
請勿改動主函數(shù)main和其他函數(shù)中的任何內(nèi)容,僅在fun函數(shù)的橫線上填入所編寫的若干表達(dá)式或語句。
試題程序:
#include
int fun(int x)
{
int i, s;
s = ___1___;
for (i=2; ___2___; i+=2)
s += i;
return s;
}
main()
{
int n;
do
{
printf("\nPlease enter natural numbers n:");
scanf("%d", &n);
} while (n <= 0);
printf("\n2?3?1y???¨×?è?êy%dμ??÷??êy??oí?a%d\n", n, fun(n));
}
第1處填空:0
第2處填空:i<=x或x>=i
改錯題
下列給定程序中,函數(shù)fun的功能是:求出兩 個非0正整數(shù)的 最大公約數(shù)并作為函數(shù)值,
例如num1 和um2分別輸入49和21,則輸出 的最大公約數(shù)為7,若給num1 和um2分別輸入27和81,則最大公約數(shù)為27。
請改正程序中的錯誤,使其能得出正確結(jié)果。
注意:不要改動main函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
試題 程序:
#include
int fun(int a, int b)
{
int r, t;
/********found********/
if (a < b)
{
t = a;
b = a;
b = t;
}
r = a%b;
while (r != 0)
{
a = b;
b = r;
r = a%b;
}
/********found********/
return (a);
}
main()
{
int num1, num2, a;
printf("Input num1 num2 : ");
scanf("%d%d", &num1, &num2);
printf("num1=%d num2=%d\n\n", num1, num2);
a = fun(num1, num2);
printf("The maximun common divisor is %d\n\n", a);
}
第1處:b=a;應(yīng)改為a=b;
第2處:return (a);應(yīng)改為return(b);
編程題
請編寫一個函數(shù)FUN,它的功能是:將SS所指字符串中所有下標(biāo)為奇數(shù)位置上的字母轉(zhuǎn)換為大寫(若該位置上不是字母,則不轉(zhuǎn)換)。
例如,若輸入abc4EFg,則應(yīng)輸出aBc4EFg
注意:部分源程序給出如下。
請勿改動主函數(shù)main和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)fun的花括號中填入所編寫的若干語句。
試題程序:
#include
#include
#include
void fun ( char *ss)
{
}
main( )
{
char tt[81];
FILE *out;
printf("\n Please enter an string within 80 characters:\n");
gets( tt );
printf("\n\nAfter changing, the string\n %s\n", tt );
fun( tt );
printf( "\nbecomes \n %s\n", tt );
out=fopen("out.dat", "w");
strcpy(tt, "Please enter an string within 80 characters:");
fun( tt );
fprintf(out, "%s", tt );
fclose(out);
}
答案是:
void fun(char *ss)
{
int i,n;
n=strlen(ss);
for(i=1;i if (ss[i]>=’a’&&ss[i]<=’z’) ss[i]=ss[i]-32; }
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |