填空題
請補充fun函數,該函數的功能是:分類統(tǒng)計一個字符串中元音字母和其它字符的個數(不區(qū)分大小寫)。
例如,輸入aeiouAUpqr,記過為A:2 E:1 I:1 O:1 U:2 other:3
注意:部分源程序給出如下
請勿改動主函數main和其他函數中的任何內容,僅在fun函數的橫線上填入所編寫的若干表達式或語句。
試題程序:
#include
#include
#define N 100
void fun(char *str, int bb[])
{
char *p = str;
int i = 0;
for (i=0; i<6; i++)
___1___;
while (*p)
{
switch (*p)
{
case 'A':
case 'a':
bb[0]++;
break;
case 'E':
case 'e':
bb[1]++;
break; 來源:考試大
case 'I':
case 'i':
bb[2]++;
break;
case 'O':
case 'o':
bb[3]++;
break;
case 'U':
case 'u':
bb[4]++;
break;
default:
___2___;
}
___3___
}
}
main()
{
char str[N], ss[5] = "AEIOU";
int i;
int bb[6];
printf("Input a string: \n");
gets(str);
printf("the string is: \n");
puts(str);
fun(str, bb);
for (i=0; i<5; i++)
printf("\n%c:%d", ss[i], bb[i]);
printf("\nother:%d", bb[i]);
}
第1處填空:bb[i]=0或*(bb+i)=0
第2處填空:bb[5]++或++bb[5]或bb[5]=bb[5]+1或bb[5]+=1
第3處填空:p++;或++p;或p+=1;或p=p+1;
改錯題
下列給定程序中,函數fun的功能是:將長整型數中每一位上為奇數的數依次取出,構成一個新數放在t中,高位仍在高位,低位仍在低位,當s中的數為87653142時,t 中的數為7531。
請改正程序中的錯誤,使其能得出正確結果。
注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構!
試題 程序:
#include
#include
void fun(long s, long *t)
{
int d;
long s1 = 1;
/********found********/
t = 0;
while (s > 0)
{
d = s%10;
/********found********/
if (d%2 == 0)
{
*t = d*s1 + *t;
s1 *= 10;
}
s /= 10;
}
}
main()
{
long s, t;
printf("\nPlease enter s: ");
scanf("%ld", &s);
fun(s, &t);
printf("The result is: %ld\n", t);
}
第1處:t =0;應改為*t =0;
第2處:if (d%2 ==0)應改為if(d%2!=0)
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內蒙古 |