Batdxaz计算机二级C语言上机模拟试题10套(含解析) 下载本文

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 #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 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(\}

答案及评析:

fun (int a[][M]) {

int i,j,min=a[0][0]; for(i=0;i<4;i++) for(j=0;ja[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 #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':