1、 . 一、 单项选择题 1.〔 A 〕是构成C语言程序的根本单位。 A、函数 B、过程 C、子程序 D、子例程 2.C语言程序从C开场执行。 A) 程序中第一条可执行语句 B) 程序中第一个函数 C) 程序中的main函数
2、 D) 包含文件中的第一个函数 3、以下说法中正确的选项是〔 C 〕。 A、C语言程序总是从第一个定义的函数开场执行 B、在C语言程序中,要调用的函数必须在main( )函数中定义 C、C语言程序总是从main( )函数开场执行 D、C语言程序中的main( )函数必须放在程序的开场局部 4.以下关于C语言的说法错误的选项是〔 B 〕 。 A) C程序的工作过程是编辑、编译、连接、运行 B) C语言不区分大小写。 C) C程序的三种根本构造是顺序、选择、循环 D) C程序从main函数开场执行 5.以下正确的标识符是
3、〔C 〕。 A.-a1 B.a[i] C.a2_i D.int t 6.以下C语言用户标识符中合法的是〔 B 〕。 A)3ax B)x C)case D)-e2 E)union 7.以下四组选项中,正确的C语言标识符是〔 C 〕。 A〕 %xB〕 a+b C〕a123D〕123 8、以下四组字符串中都可以用作C语言程序中的标识符的是〔 A 〕。 A、print _3d db8 aBc B、I\am one_half start$it 3pai
4、 C、str_1 Cpp pow while D、Pxq My->book line# His.age 9.C语言中的简单数据类型包括〔D 〕。 A、整型、实型、逻辑型 B、整型、实型、逻辑型、字符型 C、整型、字符型、逻辑型 D、整型、实型、字符型 10.在C语言程序中,表达式5%2的结果是C。 A)2.5 B)2 C)1 D)3 11.如果int a=3,b=4;那么条件表达式"a
5、int x=2,y=3,z=4 那么表达式x 6、 B.b=(float)(1/a)
C.b=1/(float)a D.b=1/(a*1.0)
16. 假设“int n; float f=13.8;〞,那么执行“n=(int)f%3”后,n的值是〔A〕
A.1 B.4 C.4.333333 D.4.6
17. 以下对一维数组a的正确说明是:D
A) char a〔10〕; B) int a[];
C)int k=5,a[k]; D〕char a[3]={‘a’,’b’,’c’};
18.以下能对一维数 7、组a进展初始化的语句是: ( C )
A. int a[5]=(0,1,2,3,4,) B. int a(5)={}
C. int a[3]={0,1,2} D. int a{5}={10*1}
19.在C语言中对一维整型数组的正确定义为 D。
A)int a(10); B)int n=10,a[n];
C)int n;a[n]; D)#define N 10
int a[N];
20、:int a[10]; 那么对a数组元素的正确引用是〔 D 〕。
A、a[10] B、a[3.5] 8、 C、a(5) D、a[0]
21.假设有以下数组说明,那么i=10;a[a[i]]元素数值是〔 B 〕。
int a[12]={1,4,7,10,2,5,8,11,3,6,9,12};
A.10 B.9 C.6 D.5
22.假设有说明:int a[][3]={{1,2,3},{4,5},{6,7}}; 那么数组a的第一维的大小为: ( B )
A. 2 B. 3 C. 4 D.无确定值
5 7 D) 3 6 9
23.对二维数组的正确定义是〔C 〕
A.int a[ ] [ ] 9、{1,2,3,4,5,6}; B.int a[2] [ ]={1,2,3,4,5,6};
C.int a[ ] [3]={1,2,3,4,5,6}; D.int a[2,3]={1,2,3,4,5,6};
24.int a[3][4];那么对数组元素引用正确的选项是__C___
A)a[2][4] B)a[1,3] C)a[2][0] D)a(2)(1)
25.C语言中函数返回值的类型是由A 决定的.
A)函数定义时指定的类型 B) return语句中的表达式类型
C) 调用该函数时的实参的数据类型 D) 形参的数据类型
10、
26. 在C语言中,函数的数据类型是指( A )
A 函数返回值的数据类型 B. 函数形参的数据类型
C 调用该函数时的实参的数据类型 D.任意指定的数据类型
27. 在函数调用时,以下说法正确的选项是〔B 〕
A.函数调用后必须带回返回值
B.实际参数和形式参数可以同名
C.函数间的数据传递不可以使用全局变量
D.主调函数和被调函数总是在同一个文件里
28.在C语言中,表示静态存储类别的关键字是: 〔 C〕
A) auto B) register C) static D) extern
29.未指定存储类别的变量, 11、其隐含的存储类别为〔 A〕。
A)auto B)static C)extern D)register
30. 假设有以下说明语句:
struct student
{ int num;
char name[ ];
float score;
}stu;
那么下面的表达不正确的选项是: ( D )
A. struct是构造体类型的关键字
B. struct student 是用户定义的构造体类型
C. num, score都是构造体成员 12、名
D. stu是用户定义的构造体类型名
31.假设有以下说明语句:
struct date
{ int year;
int month;
int day;
}brithday;
那么下面的表达不正确的选项是__C___.
A) struct是声明构造体类型时用的关键字
B) struct date 是用户定义的构造体类型名
C) brithday是用户定义的构造体类型名
D) year,day 都是构造体成员名
32. 13、以下对构造变量stul中成员age的非法引用是B
struct student
{ int age;
int num;
}stu1,*p;
p=&stu1;
A) stu1.age B) student.age C) p->age D) (*p).age
33.设有如下定义:
struck sk
{int a;
float b;
}data;
int*p;
假设要使P指向data中的a域,正确的赋值语句是C
A) p=&a; B) p=data.a; C) p=&data.a; D)*p=data.a;
34.设有以下说明语句:
type 14、def struct stu
{ int a;
float b;
} stutype;
那么下面表达中错误的选项是〔 D〕。
A、struct是构造类型的关键字
B、struct stu是用户定义的构造类型
C、a和b都是构造成员名
D、stutype是用户定义的构造体变量名
35. 语句int *p;说明了C。
A)p是指向一维数组的指针
B)p是指向函数的指针,该函数返回一int型数据
C)p是指向int型数据的指针
D)p是函数名,该函数返回一指向in 15、t型数据的指针
36.以下不正确的定义是〔 A 〕。
A. int *p=&i,i; B.int *p,i;
C.int i,*p=&i; D.int i,*p;
37. 假设有说明:int n=2,*p=&n,*q=p,那么以下非法的赋值语句是: 〔D 〕
A〕p=q B〕*p=*q C〕n=*q D〕p=n
38.有语句:int a[10],;那么B是对指针变量p的正确定义和初始化。
A)int p=*a; B)int *p=a; C)int p=&a; D)int 16、 *p=&a;
39.假设有说明语句“int a[5],*p=a;〞,那么对数组元素的正确引用是( C )。
A.a[p] B.p[a] C.*(p+2) D.p+2
40. 有如下程序
int a[10]={1,2,3,4,5,6,7,8,9,10},*P=a;
那么数值为9的表达式是B
A) *P+9 B) *(P+8) C) *P+=9 D) P+8
41. 在C语言中,以 D 作为字符串完毕标志
A)’\n’ B)’’C) ’0’ D)’\0’
42.以 17、下数据中属于“字符串常量〞的是〔 A 〕。
A.“a〞 B.{ABC} C.‘abc\0’ D.‘a’
43.char x[]="hello", y[]={'h','e','a','b','e'};, 那么关于两个数组长度的正确描述是B .
A)一样 B)x大于y C)x小于y D)以上答案都不对
44. 下面各函数中能实现翻开文件功能的是A
A)fopen B) fgetcC) fputc D) fclose
45. 以下语句中,把变量fp说明为一个文件型指针的是( A ) 。
A) FILE 18、 *fp; B) FILE fp;
C) file *fp; D) file fp;
46.以读写方式翻开一个已有的文本文件file1,并且FILE *fp,下面fopen函数正确的调用方式是( B )。
A.fp=fopen(“file1”,“r〞)
B.fp=fopen(“file1”,“r+〞)
C.fp=fopen(“file1”,“rb〞)
D.fp=fopen(“file1”,“w〞)
二、 读程序
根本输入输出及流程控制
1.
#include 19、f (c==a+b)
printf("yes\n");
else
printf("no\n");
}
运行结果为:no
2.
#include 20、)
if(y<0)
z=0;
else
z=z+1;
printf(“%d\n〞,z);
}
运行结果为:5
4.
#include 21、de < stdio .h >
main ( )
{ float c=3.0 , d=4.0;
if ( c>d ) c=5.0;
else
if ( c==d ) c=6.0;
else c=7.0;
printf ( “%.1f\n〞,c ) ;
}
运行结果为:7.0
6.
#include 22、tf("%d is a positive odd\n", m); }
else
{ if (m % 2 == 0) printf("%d is a negative even\n", m);
else printf("%d is a negative odd\n", m); }
}
假设键入-9,那么运行结果为:-9 is a negative odd
7.
#include 23、
2
3
8.
#include 24、include 25、
while(c!='?') {putchar(c); c=getchar();}
}
如果从键盘输入abcde?fgh〔回车〕
运行结果为:abcde
12.
#include 26、 }
}
当输入为ab*AB%cd#CD$时,运行结果为:ABABCDCD
13.
#include 27、rintf(“%c〞,’A’);
case ‘B’ : printf(“%c〞,’B’); break;
default: printf(“%s\n〞,〞other〞);
} }
当从键盘输入字母A时,运行结果为:AB
15.
#include 28、结果为:10
16.
#include 29、 }
}
运行结果为:
70-80
60-70
17.
#include 30、de 31、10, y<10; x--, y++)
x/=2, y+=2;
printf(“x=%d,y=%d\n〞,x,y);
}
运行结果为:
x=0,y=12
21.
#include 32、
数组
1.
#include 33、",a[i]);
}
运行结果为:
5 4 3 2 1 0
3.
#include 34、3][3]={1,2 ,3};
main( )
{ printf(“%d,〞, m[1][0]+n[0][0]);
printf(“%d\n〞,m[0][1]+n[1][0]);
}
运行结果为:
3,0
5.
#include 35、main( )
{ int n[3][3], i, j;
for(i=0;i<3;i++ )
{for(j=0;j<3;j++ )
{n[i][j]=i+j;
printf(“%d 〞, n[i][j]);
}
printf(“\n〞);
}
}
运行结果为:
0 1 2
1 2 3
2 3 4
7.
#include 36、’*’},{‘_’,’_’,’*’}};
int i,j;
for(i=0;i<5;i++)
{
for(j=0;j<5;j++)
printf(“%c〞,diamond[i][j]);
printf(“\n〞);
}
}注:“_〞代表一个空格。
运行结果为:
*
* *
* *
* *
*
8.
#include 37、 for(i=0;i<10;i++)
{ if(i%4==0)
printf(“\n〞);
printf(“%d 〞,f[i]);
}
}
运行结果为:
1 1 2 3
5 8 13 21
34 55
9.
#include “stdio.h〞
func(int b[ ])
{ int j;
for(j=0;j<4;j++)
b[j]=j;
}
main( )
{ int a[4], i;
func(a 38、);
for(i=0; i<4; i++)
printf(“%2d〞,a[i]);
}
运行结果为:
0 1 2 3
10.
#include 39、3;j++)
aver=x[j]*aver;
return〔aver〕;
}
运行结果为:
ave= 36.00
11.
#include 40、运行结果为:
1 4 2 5 3 6
12.
#include 41、nt x[4][4],y[4][4];
for(j=0;j<4;j++)
for(k=j;k<4;k++)
x[j][k]=j+k;
for(j=0;j<4;j++)
for(k=j;k<4;k++)
y[k][j]=x[j][k];
for(j=0;j<4;j++)
for(k=0;k<4;k++)
printf("%d,",y[j][k]);
}
运行结果为:
0,0,0,0,1,2,0,0,2,3,4,0,3,4,5,6
函数
1.
#include 42、)
{return (a- b);}
main()
{int x, y, result = 0;
scanf("%d,%d", &x,&y );
result = Sub(x,y ) ;
printf("result = %d\n",result);
}
当从键盘输入:6,3运行结果为:
result =3
2.
#include 43、 {
int a=3,b=5,abmin ;
abmin = min(a,b);
printf(“min is %d〞, abmin);
}
运行结果为:
min is 5
3.
#include 44、c(int x,int y)
{int m=1;
return(x*y-m);
}
main()
{int a=2,b=3;
printf("%d\n",m);
printf("%d\n",func(a,b)/m);
}
运行结果为:
4
1
5.
#include 45、r=15
6.
#include 46、
}while(num);
return k;
}
main()
{ unsigned n=26;
printf(“%d\n〞,fun6(n));
}
运行结果为:12
8.
#include 47、
指针
1.
# include < stdio .h >
main ( )
{ int x[ ] = {10, 20, 30, 40, 50 };
int *p ;
p=x;
printf ( “%d〞, *(p+2 ) );
}
运行结果为:
30
2.
#include 48、为:
ch=f
3.
#include 49、>
main( )
{ int a[ ]={1, 2, 3, 4, 5, 6};
int x, y, *p;
p = &a[0];
x = *(p+2);
y = *(p+4);
printf(“*p=%d, x=%d, y=%d\n〞, *p, x, y);
}
运行结果为:
*p=1, x=3, y=5
6.
#include 50、char(*ptr);
}
运行结果为:
Prom
7.
#include
struct st
{int x;
int y;
} a[2]={5, 7, 2, 9};
main()
{
printf("






