1.填空题 请补充函数fun(),该函数的功能是:从‘a’到‘z’统计一个字符串中所有字母字符各自出现的次数,结果保存在数组alf中。注意:不区分大小写,不能使用字符串库函数。 例如,输入:“A=abc+5*c”,结果为:a=2,b=1,c=2。 注意:部分源程序给出如下。 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的横线上填入所编写的若干表达式或语句。 试题程序: #include #include #define N 100 void fun(char *tt,int alf[]) { int i; char *p=tt; for(i=0;i<26;i++) 【1】; while(*p) { if(*p>=’A’&&*p<=’Z’) 【2】; if(*p>=’a’&&*p<=’z’) alf[*p-’a’]++; 【3】; } } main() { char str[N]; char a=’a’; int alf[26],k; clrscr(); printf("
Please enter a char string:"); scanf("%s",str); printf("
**The original string**
"); puts(str); fun(str,alf); printf("
**The number of letter**
"); for(k=0;k<26;k++) { if(k%5==0) printf("
"); printf("%c=%d ",a+k,alf[k]); } printf("
"); } 答案及评析: 【1】alf[i]=0 【2】*p+=32 【3】p++ 【解析】填空1:数组alf[26]用来存放字母字符出现的次数,在使用之前需要清零。填空2:题目要求不区分大小写,所以可以先将所有的大写字母都转换为对应的小写字母,然后一并记录出现的次数。将大写字母转换为对应的小写字母,只需将ASCII码加上32就可以了。填空3:指针p指向字符串tt,通过p自加1来移动指针,访问字符串中的所有字符。 2. 改错题 下列给定程序中函数fun()的功能是:从低位开始取出长整型变量s中奇数位上的数,依次构成一个新数放在t中。例如,当s中的数为4576235时,t中的数为4725。 请改正程序中的错误,使它能得到正确结果。 注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。 试题程序: #include #include /**********************found***********************/ int fun(long s,long *t) { long s1=10; *t=s; while(s>0) { /**********************found***********************/ s=s0; *t=s*s1+*t; s1=s1*10; } } main() { long s, t; clrscr(); printf("
Please enter s: "); scanf("%ld",&s); fun(s,&t); printf("The result is: %ld
",t); } 答案及评析: (1)错误:int fun(long s,long *t) 正确:void fun(long s,long *t) (2)错误:s=s0; 正确:s=s/100; 【解析】错误1:函数由指针来完成参数的传递,所以没有返回值,应定义函数的类型为void。 错误2:此处要注意特殊运算符号"%"--取余和"/"--整除的区别。将一个数整除100则可得到由其百位数以上的数组成的新数字,将一个数整除100取余则可得到由十位数和个位数组成的新数。 3. 编程题 请编写一个函数fun(),它的功能是:求出一个4×M整型二维数组中最小元素的值,并将此值返回调用函数。 注意:部分源程序给出如下。 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。 试题程序: #define M 4 #include fun (int a[][M]) { } main() { int arr[4][M]={11,3,9,35,42,-4,24,32,6,48,-32,7,23,34,12,-7}; printf("min=%d
",fun(arr)); } 答案及评析: fun (int a[][M]) { int i,j,min=a[0][0]; for(i=0;i<4;i++) for(j=0;j if(min>a[i][j]) min=a[i][j]; /*求出二维数组的最小值*/ return min; } 【解析】此类求最大值或最小值的C语言问题,我们可以采用逐个比较的方式。要求数组中的所有元素走动一遍,并从中找出最大、最小值,要注意一开始应使min存放数组中的第一个元素的值。可按逐行查找也可按逐列查找的方式,本题采用的是逐行查找的方式。即行下标在外层循环,列下标在内层循环,因为在循环的嵌套中越在内层循环,循环变化就越快。
相关资料
|