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(\ scanf(\
printf(\ puts(str); fun(str,alf);
printf(\ for(k=0;k<26;k++) {
if(k%5==0)
printf(\
printf(\ }
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
/**********************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(\ scanf(\ fun(s,&t);
printf(\}
答案及评析:
(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
main() {
int
arr[4][M]={11,3,9,35,42,-4,24,32,6,48,-32,7,23,34,12,-7};
printf(\}
答案及评析:
fun (int a[][M]) {
int i,j,min=a[0][0]; for(i=0;i<4;i++) for(j=0;j
min=a[i][j]; /*求出二维数组的最小值*/ return min; }
【解析】此类求最大值或最小值的C语言问题,我们可以采用逐个比较的方式。要求数组中的所有元素走动一遍,并从中找出最大、最小值,要注意一开始应使min存放数组中的第一个元素的值。可按逐行查找也可按逐列查找的方式,本题采用的是逐行查找的方式。即行下标在外层循环,列下标在内层循环,因为在循环的嵌套中越在内层循环,循环变化就越快。
模拟试题(四) 1.填空题
请补充函数fun(),该函数的功能是:分类统计一个字符串中元音字母和其他字符的个数(不区分大小写)。
例如,输入aeiouAOUpqrt,结果为A:2 E:1 I:1 O:2 U:2 other:4。 注意:部分源程序给出如下。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun()的横线上填入所编写的若干表达式或语句。 试题程序:
#include
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':