for(i=0:i<N; 1++) f(min==a[i]s) b[j++]=a[i];/*找出成绩与min相等的学生的记录,存入结构体b中+ return J /*返回最低成绩的学生人数 【解析】该程序使用循环嵌套,第1个for语句的作用是找出最小值。第2个循环的作用是找出与min相 等的成绩,也即最低成绩的学生记录,并存入b中 模拟试题(三) 1填空题 请补充函数funO,该函数的功能是:从a'到z统计一个字符串中所有字母字符各自出现的次数,结果 保存在数组a中。注意:不区分大小写,不能使用字符串库函数。 例如,输入:“A=ab+5c”,结果为:a=2,b=1,c=2 注意:部分源程序给出如下。 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的横线上填入所编写的若干表达式或语 试题程序 finc lude<conio. h> #define N 100 void fun(char *tt,int char *p=tti r(1=0;i<26;i++) while(*p) if(*p>=A&&*p<=4) if(*p>="ap<=z1) alf[*p-al+ n() char str [N]i char a=a int alf [26], ki clrscr( printf("\nPlease enter a char string: " printf("\n**The original string**\n") puts(str)i fun(str alf); printf("n**The number of letter**\n")i if(k;5=0) br printf("\n")i ntf ("c=d ,atk,alf [k])i printf("\n")i
for(i=0;i<N;i++) if(min==a[i].s) b[j++]=a[i]; /*找出成绩与min相等的学生的记录,存入结构体b中*/ return j; /*返回最低成绩的学生人数*/ } 【解析】该程序使用循环嵌套,第1个for语句的作用是找出最小值。第2个循环的作用是找出与min相 等的成绩,也即最低成绩的学生记录,并存入b中。 模拟试题(三) 1.填空题 请补充函数fun(),该函数的功能是:从‘a’到‘z’统计一个字符串中所有字母字符各自出现的次数,结果 保存在数组alf中。注意:不区分大小写,不能使用字符串库函数。 例如,输入:“A=abc+5*c”,结果为:a=2,b=1,c=2。 注意:部分源程序给出如下。 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的横线上填入所编写的若干表达式或语 句。 试题程序: #include<conio.h> #include<stdio.h> #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("\nPlease enter a char string:"); scanf("%s",str); printf("\n**The original string**\n"); puts(str); fun(str,alf); printf("\n**The number of letter**\n"); for(k=0;k<26;k++) { if(k%5==0) printf("\n"); printf("%c=%d ",a+k,alf[k]); } printf("\n"); }
答案及评析 1】ali=0 【2】·p+=32 【3】 【解析】填空1:数组alf[26]用来存放字母字符出现的次数,在使用之前需要清零。填空2:题目要求不 区分大小写,所以可以先将所有的大写字母都转换为对应的小写字母,然后一并记录出现的次数。将大写 字母转换为对应的小写字母,只需将 ASCII码加上32就可以了。填空3:指针p指向字符串tt,通过p自 加1来移动指针,访问字符串中的所有字符 2.改错题 下列给定程序中函数fun0的功能是:从低位开始取出长整型变量s中奇数位上的数,依次构成一个新数 放在中。例如,当s中的数为4576235时,t中的数为4725 请改正程序中的错误,使它能得到正确结果。 注意:不要改动main函数,不得增行或删行,也不得更改程序的结构 试题程序 include<stdio. h> include <conio. h> ★★★大★★大★★★★★大大★ 大大★食 int fun (long s, long *t) while(s>0) s=s8100; ★七=s各10*s1+★t; printf("\nPlease enter s: " scanf("ld",&s) printf("The result is: gld\n " t) 答案及评析 (1)错误: int fun( longs. long * t) 正确: void fun( 中t (2)错误:s=s%100 正确:s=s/ 【解析】错误1:函数由指针来完成参数的传递,所以没有返回值,应定义函数的类型为void 错误2:此处要注意特殊运算符号%"取余和"-整除的区别。将一个数整除100则可得到由其百位 数以上的数组成的新数字,将一个数整除100取余则可得到由十位数和个位数组成的新数
答案及评析: 【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<stdio.h> #include <conio.h> /**********************found***********************/ int fun(long s,long *t) { long s1=10; *t=s%10; while(s>0) { /**********************found***********************/ s=s%100; *t=s%10*s1+*t; s1=s1*10; } } main() { long s, t; clrscr(); printf("\nPlease enter s: "); scanf("%ld",&s); fun(s,&t); printf("The result is: %ld\n ",t); } 答案及评析: (1)错误:int fun(long s,long *t) 正确:void fun(long s,long *t) (2)错误:s=s%100; 正确:s=s/100; 【解析】错误1:函数由指针来完成参数的传递,所以没有返回值,应定义函数的类型为void。 错误2:此处要注意特殊运算符号"%"--取余和"/"--整除的区别。将一个数整除100则可得到由其百位 数以上的数组成的新数字,将一个数整除100取余则可得到由十位数和个位数组成的新数
3.编程题 请编写一个函数fun),它的功能是:求出一个4×M整型二维数组中最小元素的值,并将此值返回调用 注意:部分源程序给出如下。 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句 试题程序 #define M 4 #include <stdio. h> fun (int a[] [MI) nt arr[4][M]={11,3,9,35,42,-4,24,32,6,48,-32,7,23,34,12,-7} printf("min=8d\n", fun(arr))i 答案及评析 fun (int a[] [MI) int i,j, min=a[0][0]i for(i=0;i<4;i++) for(j=0: 3<M; 3++) if(min>a[i][j]) min=a[i][j];/*求出二维数组的最小值+/ return min 【解析】此类求最大值或最小值的C语言问题,我们可以采用逐个比较的方式。要求数组中的所有元 素走动一遍,并从中找出最大、最小值,要注意一开始应使min存放数组中的第一个元素的值。可按逐行查 找也可按逐列查找的方式,本题采用的是逐行查找的方式。即行下标在外层循环,列下标在内层循环 为在循环的嵌套中越在内层循环,循环变化就越快。 模拟试题(四) 1填空题 补充函数funO,该函数的功能是:分类统计一个字符串中元音字母和其他字符的个数(不区分大小 写) 例如,输入 aeIouAOUpqrt,结果为A2E:l:102U2 other:4 注意:部分源程序给出如下。 请勿改动主函数man和其他函数中的任何内容,仅在函数fumO的横线上填入所编写的若干表达式或语 句 试题程序 #include<stdio. h> include<conio. h> #define N 100 fun(char *str, int bb[]) char *p=str
3. 编程题 请编写一个函数fun(),它的功能是:求出一个4×M整型二维数组中最小元素的值,并将此值返回调用 函数。 注意:部分源程序给出如下。 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。 试题程序: #define M 4 #include <stdio.h> 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\n",fun(arr)); } 答案及评析: fun (int a[][M]) { int i,j,min=a[0][0]; for(i=0;i<4;i++) for(j=0;j<M;j++) if(min>a[i][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<stdio.h> #include<conio.h> #define N 100 void fun(char *str,int bb[]) { char *p=str;
for(i=0;i<6;i++) 】 switch(*p) case 'a: bb[0]++ break case E i:bb[2]+ case 'o: bb[3]++ break; case U case 'u': bb[ 4]++ break char str [N], Ss [6]=AEIOu"; printf("Input a string: \n") gets(str); printf("the string is: \n")i for(i=0;i<5;:i++) printf("n是c:影d",ss[i],bb[i]) printf("\nother: 8d", bb[i]) 答案及评析 1】bb[=0 【2】bb[5}++ 【3】p+ 【解析】填空1:数组bb[6]用来存放5个元音字母和其他字符的个数,在使用之前需要清零 填空2:数组元素bb[5]用来存放其他字符的个数,当指针p所指的字符不是元音字母时,则认为是其他 字符,bb[5]加1。填空3:指针p指向字符串str,通过p自加1来移动指针,访问字符串中的所有字符 2.改错题 下列给定的程序中,函数fn0的功能是:计算并输出k以内最大的6个能被7或11整除的自然数之和。K 的值由主函数传入,若k的值为500,则函数的值为2925 请改正程序中的错误,使它能得到正确结果 注意:不要改动main函数,不得增行或删行,也不得更改程序的结构 试题程序 include<stdio.h> include <conio. h int fun (int k) tm=0,mc=0
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[6]="AEIOU"; int i; int bb[6]; clrscr(); 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 【2】bb[5]++ 【3】p++; 【解析】填空1:数组bb[6] 用来存放5个元音字母和其他字符的个数,在使用之前需要清零。 填空 2:数组元素 bb[5] 用来存放其他字符的个数,当指针 p 所指的字符不是元音字母时,则认为是其他 字符,bb[5]加 1。填空 3:指针 p 指向字符串 str,通过 p 自加 1 来移动指针,访问字符串中的所有字符。 2. 改错题 下列给定的程序中,函数fun()的功能是:计算并输出k以内最大的6个能被7或11整除的自然数之和。K 的值由主函数传入,若k的值为500,则函数的值为2925。 请改正程序中的错误,使它能得到正确结果。 注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。 试题程序: #include<stdio.h> #include <conio.h> int fun(int k) { int m=0,mc=0, j;