形考任务 2
一、 选择题(共 20 分, 每小题 2 分)
题目1
当处理特定问题时的循环次数已知时, 通常采用的语句是( )。
[答案]a. for
题目2
在 switch 语句的每个 case 块中, 假定都是以 break 语句结束的, 则此 switch 语句容易被改写成的语句是( )。
[答案]b. if
题目3
for 语句能够被改写成的语句是( )。
[答案]d. while
题目4
下面循环语句执行结束后输出的 i 值为( )。for(int i=0; i<n; i++) if(i>n/2) {cout<<i<<endl; break; }
[答案]b. n/2+1
题目5
在下面循环语句中, 内层循环体 S 语句的执行总次数为( )。for(int i=0; i<n; i++)for(int j=i; j<n; j++) S;
[答案]d. n(n+1) /2
题目6
在下面的 do 循环语句中, 其循环体被执行的次数为( )。
int i=0; do i++; while(i*i<10) ;
[答案]a. 4
题目7
在下面的一维数组定义中, 有语法错误的选项是( )。
[答案]c. int a[] ;
题目8
在下面的二维数组定义中, 语法正确的选项是( )。
[答案]c. int a[] [3] ={{1, 3, 5} , {2} } ;
题目9
假定一个二维数组的定义语句为“int a[3][4]={{3, 4} , {2, 8, 6} } ; ”, 则元素 a[1][1]的值为( )。
[答案]d. 8
题目10
假定一个二维数组的定义语句为“int a[3][4]={{3, 4} , {2, 8, 6} } ; ”, 则元素 a[2][1]的值为( )。
[答案]a. 0
题目11
在执行“typedef int DataType; ” 语句后, 标识符 DataType 与保留字 int 具有完全相同的含义和作用。
[答案]对
题目12
在 switch 语句中, 每个 case 和冒号之间的表达式只能是常量。
[答案]对
题目13
为了结束本层循环类语句或 switch 语句的执行过程, 在语句体中需要使用 break 语句。
[答案]对
题目14
在程序中执行到 break 语句时, 将结束所在函数的执行过程, 返回到调用该函数的位置。
[答案]错
题目15
在程序执行完成任一个函数调用后, 将结束整个程序的执行过程, 返回到操作系统或 C 语言集成开发环境界窗口。
[答案]错
题目16
假定一维数组的定义为“char* a[8]; ”, 则该数组所含元素的个数大于 8。
[答案]错
题目17
假定二维数组的定义为“int a[3][5]; ”, 则该数组所占存储空间的字节数为 60。
[答案]对
题目18
假定二维数组的定义为“char a[M][N]; ”, 则该数组所含元素的个数为 M+N。
[答案]错
题目19
假定二维数组的定义为“double a[M][N]; ”, 则每个数组元素的行下标取值范围在 0~M-1 之间。
[答案]对
题目20
假定二维数组的定义为“double a[M][N]; ”, 则每个数组元素的列下标取值范围在 0~N 之间。
[答案]错
题目21
存储一个空字符串需要占用 0 个字节的存储空间。
[答案]错
题目22
使用“typedef char BB[10][50]; ” 语句定义标识符 BB 为含有 10 行 50 列的二维字符数组类型。
[答案]对
题目23
存储字符’ a’ 需要占用 1 个字节的存储空间。
[答案]对
题目24
空字符串的长度为 1。
[答案]错
题目25
字符串”a: xxk数据”的长度为 13。
[答案]错
题目26
为了存储一个长度为 n 的字符串, 所使用的字符数组的长度至少为 n+1。
[答案]对
题目27
strcmp 函数用于进行两个字符串之间的比较。
[答案]对
题目28
strcpy 函数用于把一个字符串拷贝到另一个字符数组空间中。
[答案]对
题目29
一个二维字符数组 a[10][20]能够最多存储 9 个字符串。
[答案]错
题目30
一个二维字符数组 a[10][20]能够存储的每个字符串的长度不超过 20。
[答案]错
三、 填空题: 写出下列每个程序运行后的输出结果(共 40 分, 每小题 4 分)
题目 31
#include<stdio.h>
void main()
{
int x=5;
switch(2*x-3) {
case 4: printf(“%d “,x);
case 7: printf(“%d “,2*x+1);
case 10: printf(“%d “,3*x-1); break;
default: printf(“%s”,”defaultn”);
}
}
[答案] 11 14
题目 32
#include<stdio.h>
void main() {
int i,s=0;
for(i=1;i<=5;i++) s+=i*i;
printf(“s=%dn”,s);
}
[答案] s=55
题目 33
#include<stdio.h>
void main() {
int i, s1=0, s2=0;
for(i=0;i<10;i++)
if(i%2) s1+=i; else s2+=i;
printf(“%d %dn”,s1,s2);
}
[答案]25 20
题目 34
#include<stdio.h>
void main() {
int n=6,y=1;
while(n) y*=n–;
printf(“y=%dn”,y);
}
[答案] y=720
题目 35
#include<stdio.h>
const int M=20;
void main()
{
int i,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 %dn”,c2,c3,c5);
}
[答案] 10 6 4
题目 36
#include<stdio.h>
void main()
{
int i,s;
for(i=1,s=0;i<10;i++) {
if(i%3==0) continue;
s+=i;
}
printf(“%dn”,s);
}
[答案] 27
题目 37
#include<stdio.h>
void main() {
int a[8]={12,39,26,41,55,63,72,40};
int i, i1=0, i2=0;
for(i=0;i<8;i++)
if(a[i]%2==1) i1++; else i2++;
printf(“%d %dn”,i1,i2);
}
[答案]4 4
题目 38
#include<stdio.h>
int a[10]={4,5,6,15,20,13,12,7,8,9};
void main()
{
int i,s[4]=0;
for(i=0; i<10; i++) {
switch(a[i]%4) {
case 0: s[0]+=a[i];break;
case 1: s[1]+=a[i];break;
case 2: s[2]+=a[i];break;
default: s[3]+=a[i];break;
}
}
for(i=0; i<4; i++) printf(“%d “,s[i]);
}
[答案] 44 27 6 22
题目 39
#include<stdio.h>
void main() {
char a[]=”abcdbfbgacd”;
int i1=0, i2=0, i=0;
while(a[i]) {
if(a[i]==’a’) i1++;
if(a[i]==’b’) i2++;
i++;
}
printf(“%d %d %dn”,i1,i2,i);
}
[答案] 2 3 11
题目 40
#include<stdio.h>
void main() {
int a[3][4]={{1,2,7,8},{5,6,10,6},{9,12,3,4}};
int m=a[0][0];
int i,j;
for(i=0; i<3; i++)
for(j=0; j<4; j++)
if(a[i][j]>m) m=a[i][j];
printf(“%dn”,m);
}
[答案] 12
题目 41
编写一个函数,函数头格式为“double Mean(double a[M][N],int m,int n)”,要求返回二维数组a[m][n]中所有元素的平均值,假定在计算过程中采用变量v存放平均值。
[答案] double Mean(double a[M][N],int m,int n)
{
int i,j;
double v=0.0;
for(i=0; i<m; i++)
for(j=0; j<n; j++) v+=a[i][j];
v/=m*n;
return v;
}
题目 42
编写一个递归函数“int FF(int a[], int n)”,求出数组a中所有n个元素之积并返回。
[答案] int FF(int a[], int n)
{
if(n==1) return a[n-1];
else return a[n-1]*FF(a,n-1);
}
题目 43
编写一个主函数,利用while循环,求出并显示满足不等式的最小n值。
[答案]
#include<stdio.h>
void main()
{
int i=0; double s=0; //或int i=1; double s=1;
while(s<5) s+=(double)1/++i;
printf(“n=%dn”,i);
}
题目 44
编写一个主函数,求出满足不等式22+42+…+n2<1000的最大n值,假定分别用i和s作为取偶数值和累加值的变量,并限定使用do循环编程。
[答案] #include<stdio.h>
void main()
{
int i=0; //用i作为依次取值偶数的变量
int s=0; //用s作为累加变量
do {
i+=2;
s+=i*i;
}while(s<1000);
printf(“n=%dn”,i-2);
}
题目 45
编写一个主函数,计算并输出12+22+…+n2值,其中n值由键盘输入。
[答案] #include<stdio.h>
void main()
{
int i; //用i作为计数(循环)变量
int s=0; //用s作为累加变量
int n;
printf(“输入一个自然数: “);
scanf(“%d”,&n);
for(i=1; i<=n; i++) s+=i*i;
printf(“s=%dn”,s);
}