国开形成性考核高分题库之C语言程序设计850817.docx
- 文档编号:613534
- 上传时间:2022-10-11
- 格式:DOCX
- 页数:11
- 大小:16.87KB
国开形成性考核高分题库之C语言程序设计850817.docx
《国开形成性考核高分题库之C语言程序设计850817.docx》由会员分享,可在线阅读,更多相关《国开形成性考核高分题库之C语言程序设计850817.docx(11页珍藏版)》请在冰豆网上搜索。
国开形成性考核高分题库之C语言程序设计850817
C语言程序设计
一、选择题(共20分,每小题2分)
当处理特定问题时的循环次数已知时,通常采用的语句是()。
A.for
B.while
C.do-while
D.switch
答案:
A.
在switch语句的每个case块中,假定都是以break语句结束的,则此switch语句容易被改写成的语句是()。
A.for
B.if
C.do
D.while
答案:
B.
for语句能够被改写成的语句是()。
A.复合
B.if
C.switch
D.while
答案:
D.
下面循环语句执行结束后输出的i值为()。
for(inti=0;i A.n/2 B.n/2+1 C.n/2-1 D.n-1 答案: B. 在下面循环语句中,内层循环体S语句的执行总次数为()。 for(inti=0;i for(intj=i;j A.n2 B.(n+1)/2 C.n(n-1)/2 D.n(n+1)/2 答案: D. 在下面的do循环语句中,其循环体被执行的次数为()。 inti=0;doi++;while(i*i<10); A.4 B.3 C.5 D.2 答案: A. 在下面的一维数组定义中,有语法错误的选项是()。 A.inta[]={1,2,3}; B.inta[10]={0}; C.inta[]; D.inta[5]; 答案: C. 在下面的二维数组定义中,语法正确的选项是()。 A.inta[5][]; B.inta[][5]; C.inta[][3]={{1,3,5},{2}}; D.inta[](10); 答案: inta[][3]={{1,3,5},{2}}; 假定一个二维数组的定义语句为“inta[3][4]={{3,4},{2,8,6}};”,则元素a[1][1]的值为()。 A.2 B.4 C.6 D.8 答案: D. 假定一个二维数组的定义语句为“inta[3][4]={{3,4},{2,8,6}};”,则元素a[2][1]的值为()。 A.0 B.4 C.8 D.6 答案: A. 二、判断题(共20分,每小题1分。 叙述正确则回答“是”,否则回答“否”) 在执行“typedefintDataType;”语句后,标识符DataType与保留字int具有完全相同的含义和作用。 A.对 B.错 答案: 对 在switch语句中,每个case和冒号之间的表达式只能是常量。 A.对 B.错 答案: 对 为了结束本层循环类语句或switch语句的执行过程,在语句体中需要使用break语句。 A.对 B.错 答案: 对 在程序中执行到break语句时,将结束所在函数的执行过程,返回到调用该函数的位置。 A.对 B.错 答案: 错 在程序执行完成任一个函数调用后,将结束整个程序的执行过程,返回到操作系统或C语言集成开发环境界面窗口。 A.对 B.错 答案: 错 假定一维数组的定义为“char*a[8];”,则该数组所含元素的个数大于8。 A.对 B.错 答案: 错 假定二维数组的定义为“inta[3][5];”,则该数组所占存储空间的字节数为60。 A.对 B.错 答案: 对 假定二维数组的定义为“chara[M][N];”,则该数组所含元素的个数为M+N。 A.对 B.错 答案: 错 假定二维数组的定义为“doublea[M][N];”,则每个数组元素的行下标取值范围在0~M-1之间。 A.对 B.错 答案: 对 假定二维数组的定义为“doublea[M][N];”,则每个数组元素的列下标取值范围在0~N之间。 A.对 B.错 答案: 错 存储一个空字符串需要占用0个字节的存储空间。 A.对 B.错 答案: 错 使用“typedefcharBB[10][50];”语句定义标识符BB为含有10行50列的二维字符数组类型。 A.对 B.错 答案: 对 存储字符'a'需要占用1个字节的存储空间。 A.对 B.错 答案: 对 空字符串的长度为1。 A.对 B.错 答案: 错 字符串"a: \\xxk\\数据"的长度为13。 A.对 B.错 答案: 错 为了存储一个长度为n的字符串,所使用的字符数组的长度至少为n+1。 A.对 B.错 答案: 对 strcmp函数用于进行两个字符串之间的比较。 A.对 B.错 答案: 对 strcpy函数用于把一个字符串拷贝到另一个字符数组空间中。 A.对 B.错 答案: 对 一个二维字符数组a[10][20]能够最多存储9个字符串。 A.对 B.错 答案: 错 一个二维字符数组a[10][20]能够存储的每个字符串的长度不超过20。 A.对 B.错 答案: 错 三、填空题: 写出下列每个程序运行后的输出结果(共40分,每小题4分) #include voidmain() { intx=5; switch(2*x-3){ case4: printf("%d",x); case7: printf("%d",2*x+1); case10: printf("%d",3*x-1);break; default: printf("%s","default\n"); } } 答案: 1114答案: < #include voidmain(){ inti,s=0; for(i=1;i<=5;i++)s+=i*i; printf("s=%d\n",s); } 答案: s=55 #include voidmain(){ inti,s1=0,s2=0; for(i=0;i<10;i++) if(i%2)s1+=i;elses2+=i; printf("%d%d\n",s1,s2); } 答案: 2520 #include voidmain(){ intn=6,y=1; while(n)y*=n--; printf("y=%d\n",y); } 答案: y=720 #include constintM=20; voidmain() { inti,c2,c3,c5; c2=c3=c5=0; for(i=1;i<=M;i++){ if(i%2==0)c2++; if(i%3==0)c3++; if(i%5==0)c5++; } printf("%d%d%d\n",c2,c3,c5); } 答案: 1064 #include voidmain() { inti,s; for(i=1,s=0;i<10;i++){ if(i%3==0)continue; s+=i; } printf("%d\n",s); } 答案: 27 #include voidmain(){ inta[8]={12,39,26,41,55,63,72,40}; inti,i1=0,i2=0; for(i=0;i<8;i++) if(a[i]%2==1)i1++;elsei2++; printf("%d%d\n",i1,i2); } 答案: 44 #include inta[10]={4,5,6,15,20,13,12,7,8,9}; voidmain() { inti,s[4]=0; for(i=0;i<10;i++){ switch(a[i]%4){ case0: s[0]+=a[i];break; case1: s[1]+=a[i];break; case2: s[2]+=a[i];break; default: s[3]+=a[i];break; } } for(i=0;i<4;i++)printf("%d",s[i]); } 答案: 4427622 #include voidmain(){ chara[]="abcdbfbgacd"; inti1=0,i2=0,i=0; while(a[i]){ if(a[i]=='a')i1++; if(a[i]=='b')i2++; i++; } printf("%d%d%d\n",i1,i2,i); } 答案: 2311 #include voidmain(){ inta[3][4]={{1,2,7,8},{5,6,10,6},{9,12,3,4}}; intm=a[0][0]; inti,j; for(i=0;i<3;i++) for(j=0;j<4;j++) if(a[i][j]>m)m=a[i][j]; printf("%d\n",m); } 答案: 12 四、简答题: 根据下列每个题目要求编写程序(共20分,每小题4分) 编写一个函数,函数头格式为“doubleMean(doublea[M][N],intm,intn)”,要求返回二维数组a[m][n]中所有元素的平均值,假定在计算过程中采用变量v存放平均值。 答案: doubleMean(doublea[M][N],intm,intn) { inti,j; doublev=0.0; for(i=0;i for(j=0;j v/=m*n; returnv; } 编写一个递归函数“intFF(inta[],intn)”,求出数组a中所有n个元素之积并返回。 答案: intFF(inta[],intn) { if(n==1)returna[n-1]; elsereturna[n-1]*FF(a,n-1); } 编写一个主函数,利用while循环,求出并显示满足不等式的最小n值。 答案: #include voidmain() { inti=0;doubles=0;//或inti=1;doubles=1; while(s<5)s+=(double)1/++i; printf("n=%d\n",i); } 编写一个主函数,求出满足不等式22+42+...+n2<1000的最大n值,假定分别用i和s作为取偶数值和累加值的变量,并限定使用do循环编程。 答案: #include voidmain() { inti=0;//用i作为依次取值偶数的变量 ints=0;//用s作为累加变量 do{ i+=2; s+=i*i; }while(s<1000); printf("n=%d\n",i-2); } 编写一个主函数,计算并输出12+22+...+n2值,其中n值由键盘输入。 答案: #include voidmain() { inti;//用i作为计数(循环)变量 ints=0;//用s作为累加变量 intn; printf("输入一个自然数: "); scanf("%d",&n); for(i=1;i<=n;i++)s+=i*i; printf("s=%d\n",s); }
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 形成 考核 高分 题库 语言程序设计 850817