当前位置:高等教育资讯网  >  中国高校课件下载中心  >  大学文库  >  浏览文档

南开大学:《C语言程序100题(附程序答案)》试上机模拟题

资源类别:文库,文档格式:DOC,文档页数:27,文件大小:203KB,团购合买
模拟试题() 1.填空题 请补充函数fun(,该函数的功能是:把从主函数中输入的字符串2接在字符串str的后面。 例如:strl= How do",str2=“ you do?”,结果输出: How do you do? 注意:部分源程序给出如下 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的横线上填入所编写的若干表达式或语 句。
点击下载完整版文档(DOC)

模拟试题(一) 1填空题 请补充函数funO,该函数的功能是:把从主函数中输入的字符串s2接在字符串s的后面 例如:strl= How do",st2=“ you do?”,结果输出: How do you do? 注意:部分源程序给出如下。 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的横线上填入所编写的若干表达式或语 试题程序 include<stdio finc lude<conic void fun(char *strl, char *str2) char *pl=strl, char *p2=str2; while(l) for(;2】;i++) (P1+i)=t3】 (p1+i)="\0 n() char strlINstr2[] clrscr( printf("*****Input the string strl str2*大★\n") printf(" \nstl: " gets(strl printf(" \nstr2: " gets(str2)i printf("**The string strl str2**\n") uts(str1)i puts(str2); fun(strl, str2 printf(”* he new string大hn") puts(strl 答案及评析 1】·(p1+i 【2】 【3】·p2++ 【解析】填空1:变量i用来记录字符串strl的长度,当指针指到字符串str1结束标志符“\0'时,whie 循环结束,变量i停止累加。填空2:指针p2指向字符串str2,通过for循环将字符串str2接在str1后 面,循环结束的条件是指针p2所指的字符是字符串结束标志符“\0’。填空3:指针p2最初指向字符串str2 的首字符,通过自加1,使指针p2依次向后移动,指向str2的各个字符,实现将字符串str2接在strl 后面的功能 2.改错题 下列给定程序中,函数fun0的作用是:将字符串t中的小写字母都改为对应的大写字母,其他字符不变 例如,若输入"edS,dAd",则输出"EDS,DAD"。 请改正程序中的错误,使它能得到正确结果

模拟试题(一) 1.填空题 请补充函数fun(),该函数的功能是:把从主函数中输入的字符串str2接在字符串str1的后面。 例如:str1=“How do”,str2=“ you do?”,结果输出:How do you do? 注意:部分源程序给出如下。 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的横线上填入所编写的若干表达式或语 句。 试题程序: #include #include #define N 40 void fun(char *str1,char *str2) { int i=0; char *p1=str1; char *p2=str2; while(【1】) i++; for( ;【2】;i++) *(p1+i)=【3】; *(p1+i)='\0'; } main() { char str1[N],str2[N]; clrscr(); printf("*****Input the string str1 & str2*****\n"); printf(" \nstr1:"); gets(str1); printf(" \nstr2:"); gets(str2); printf("**The string str1 & str2**\n"); puts(str1); puts(str2); fun(str1,str2); printf("*****The new string *****\n"); puts(str1); } 答案及评析: 【1】*(p1+i) 【2】*p2 【3】*p2++ 【解析】填空 1:变量 i 用来记录字符串 str1 的长度,当指针指到字符串 str1 结束标志符‘\0'时,while 循环结束,变量 i 停止累加。填空 2:指针 p2 指向字符串 str2,通过 for 循环将字符串 str2 接在 str1 后 面,循环结束的条件是指针 p2 所指的字符是字符串结束标志符‘\0'。填空 3:指针 p2 最初指向字符串 str2 的首字符,通过自加 1,使指针 p2 依次向后移动,指向 str2 的各个字符,实现将字符串 str2 接在 str1 后面的功能。 2. 改错题 下列给定程序中,函数fun()的作用是:将字符串tt中的小写字母都改为对应的大写字母,其他字符不变。 例如,若输入"edS,dAd",则输出"EDS,DAD"。 请改正程序中的错误,使它能得到正确结果

注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。 试题程序 include include ★大大大 found for(i=0;tt[i];i++) /*大大★★★大大大★大★大大大★大大大★★大 found+★大★大★大大大大★大大大★大大★★★大大★/ f((tt[i]>='A')(tt[i] define N 80

注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。 试题程序: #include #include #include /**********************found***********************/ char fun(char tt[]) { int i; for(i=0;tt[i];i++) { /**********************found***********************/ if((tt[i]>='A')&&(tt[i]='A')&&(tt[i]='a')&&(tt[i] #define N 80 void fun(int *w, int p, int n) {

inta[N]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15} printf("The original data: \n")i printf("83d",a[i]) printf("\n\nEnter p: ")i scanf( "sd",&p) tf("\nThe data after moving: \n") for (i=0; i=0;j-)/*实现循环右移*/ w[j+1]=w[j] 【解析】本题采用″循环右移″的算法。和我们在前面分析的稍有不同的是,一个是整型数组,一个是字符 型数组。 模拟试题(二) 1.填空题 请补充函数funO,该函数的功能是求一维数组xN]的平均值,并对所得结果进行四舍五入(保留两位 小数) 例如:当x[10}={156,199,16.7,15.2,18.3,12.1,15.5,11.0, 10.0,160},结果为:avg=15.030000 注意:部分源程序给出如下。 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的横线上填入所编写的若干表达式或语 试题程序 include include double fun(double x[10]) double avg=0.0 double sun=o0 10;++)

} main() { int a[N]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15}; int i, p, n=15; printf("The original data:\n"); for(i=0;i=0;j--) /*实现循环右移*/ w[j+1]=w[j]; w[0]=t; } } 【解析】本题采用"循环右移"的算法。和我们在前面分析的稍有不同的是,一个是整型数组,一个是字符 型数组。 模拟试题(二) 1.填空题 请补充函数fun(),该函数的功能是求一维数组x[N]的平均值,并对所得结果进行四舍五入(保留两位 小数)。 例如:当x[10]={15.6,19.9,16.7,15.2,18.3,12.1,15.5,11.0, 10.0,16.0},结果为:avg=15.030000。 注意:部分源程序给出如下。 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的横线上填入所编写的若干表达式或语 句。 试题程序: #include #include double fun(double x[10]) { int i; long t; double avg=0.0; double sum=0.0; for(i=0;i<10;i++) 【1】; avg=sum/10;

avg=(double)t/10( return avg double avg,x[10]={15.6,19.9,16.7,15.2 18.3,12.1,15.5,11.0,10.0,16.0} clrscr( printf("\nThe original data is \n")i (i=0;i int fun o inta[3][3],mu1; nti;氵 for(i=0;i<3;i++) ★大★大大★大★大大大大大 found大★大★大★大大大大★大★大大 for(i=0;j<3;j++) scanf("d",&a[i][3])i for(i=0;i<3;i++) **大来★* found*★*★★*/ mul=mula[][jl; printf("Mul=&d\n", mul) main( fun ()i 答案及评析 (1)错误:for(i=0<3计++) 正确:for(=0j<3j++)

avg=【2】; t=【3】; avg=(double)t/100; return avg; } main() { double avg,x[10]={15.6,19.9,16.7,15.2, 18.3,12.1,15.5,11.0,10.0,16.0}; int i; clrscr(); printf("\nThe original data is :\n"); for(i=0;i int fun() { int a[3][3],mul; int i,j; mul=1; for (i=0;i<3;i++) { /**********************found***********************/ for (i=0;j<3;j++) scanf("%d",&a[i][j]); } for(i=0;i<3;i++) /**********************found***********************/ mul=mul*a[i][j]; printf("Mul=%d\n",mul); } main() { fun(); } 答案及评析: (1)错误:for (i=0;j<3;j++) 正确:for (j=0;j<3;j++)

(2)错误:mu=mu"a[ 正确:mu=mua[ 【解析】错误1:循环结构中,要给变量j赋初值0。 错误2:主对角元素的行号和列号相等,所以参加乘法的是a[,而不是a[][ 3.编程题 学生的记录由学号和成绩组成,N名学生的数据已在主函数中放入结构体数组s中,请编写函数funO, 它的功能是:把分数最低的学生数据放在h所指的数组中。注意:分数低的学生可能不只一个,函数返回分 数最低学生的人数 注意:部分源程序给出如下。 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。 试题程序 include define N 16 typedef struct char num[101 ISTREC; int fun (sTREC *a, STREC *b) main () STREC S[N]={("GA005",82},{"GA003",75},("GA002",85},{"GA004",78} "GA001",95},{"GA007",62},{"GA008",60},{"GA006",85}, "GA015",83},{"GA013",94},{"GA012",78},("GA014”,97 "GA011",60},{"GA017",65},{"GA018",60},{"GA016",74}} stEc h [N]; printf("The d lowest score \n", n) for (i=0; ia [i. s) min=a[i].s;/*找出最小值*/

(2)错误:mul=mul*a[i][j]; 正确:mul=mul*a[i][i]; 【解析】错误1:循环结构中,要给变量j赋初值0。 错误2:主对角元素的行号和列号相等,所以参加乘法的是a[i][i],而不是a[i][j]。 3. 编程题 学生的记录由学号和成绩组成,N名学生的数据已在主函数中放入结构体数组s中,请编写函数fun(), 它的功能是:把分数最低的学生数据放在h所指的数组中。注意:分数低的学生可能不只一个,函数返回分 数最低学生的人数。 注意:部分源程序给出如下。 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。 试题程序: #include #define N 16 typedef struct { char num[10]; int s ; }STREC; int fun (STREC *a, STREC *b) { } main () { STREC s[N]={{"GA005",82},{"GA003",75},{"GA002",85},{"GA004",78}, {"GA001",95},{"GA007",62},{"GA008",60},{"GA006",85}, {"GA015",83},{"GA013",94},{"GA012",78},{"GA014",97}, {"GA011",60},{"GA017",65},{"GA018",60},{"GA016",74}}; STREC h[N]; int i, n; FILE *out; n=fun(s,h); printf("The %d lowest score :\n",n); for (i=0; ia[i].s) min=a[i].s; /*找出最小值*/

for(i=0:i #define N 100 void fun(char *tt,int char *p=tti r(1=0;i=A&&*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 #include #define N 100 void fun(char *tt,int alf[]) { int i; char *p=tt; for(i=0;i='A'&&*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 include ★★★大★★大★★★★★大大★ 大大★食 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 #include /**********************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 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;ia[i][j]) min=a[i][j];/*求出二维数组的最小值+/ return min 【解析】此类求最大值或最小值的C语言问题,我们可以采用逐个比较的方式。要求数组中的所有元 素走动一遍,并从中找出最大、最小值,要注意一开始应使min存放数组中的第一个元素的值。可按逐行查 找也可按逐列查找的方式,本题采用的是逐行查找的方式。即行下标在外层循环,列下标在内层循环 为在循环的嵌套中越在内层循环,循环变化就越快。 模拟试题(四) 1填空题 补充函数funO,该函数的功能是:分类统计一个字符串中元音字母和其他字符的个数(不区分大小 写) 例如,输入 aeIouAOUpqrt,结果为A2E:l:102U2 other:4 注意:部分源程序给出如下。 请勿改动主函数man和其他函数中的任何内容,仅在函数fumO的横线上填入所编写的若干表达式或语 句 试题程序 #include include #define N 100 fun(char *str, int bb[]) char *p=str

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\n",fun(arr)); } 答案及评析: fun (int a[][M]) { int i,j,min=a[0][0]; for(i=0;ia[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;

for(i=0;i include <conio. h int fun (int k) tm=0,mc=0

int i=0; for(i=0;i #include int fun(int k) { int m=0,mc=0, j;

/*大大大★★大大★★★大大大大大大★大大大★ Found大大★大大大大大大大大大大大大大大大★大★★大/ whi1e(k>=2)&&(mc=2&&(mc=2)&(mc include char tt[81]

/**********************found***********************/ while(k>=2)&&(mc=2)&&(mc=2)&&(mc #include #include void fun(char *ss) { } main() { char tt[81]; clrscr();

点击下载完整版文档(DOC)VIP每日下载上限内不扣除下载券和下载次数;
按次数下载不扣除下载券;
24小时内重复下载只扣除一次;
顺序:VIP每日次数-->可用次数-->下载券;
共27页,试读已结束,阅读完整版请下载
相关文档

关于我们|帮助中心|下载说明|相关软件|意见反馈|联系我们

Copyright © 2008-现在 cucdc.com 高等教育资讯网 版权所有