搜档网
当前位置:搜档网 › C语言选择题复习精选

C语言选择题复习精选

C语言选择题复习精选
C语言选择题复习精选

选择题复习

1.表达式“(a=4*5, b=a*2), b-a, a+=2”的值是(C)。

A.2 B.20 C.22 D.42

2.以下是一个自定义函数的头部,其中正确的是(C )。

A.int fun(int a[ ], b) B.int fun(int a[ ], int a)

C.int fun(int*a, int b) D.int fun(char a[ ][ ], int b)

3.以下数组声明语句中正确的是(D )。

A.int n, a[n]; B.int a[ ];

C.int a[2][3]={{l},{2},{3}}; D.int a[ ][3]={{l},{2},{3}};

4.已知在某C语言编译系统中表达式sizeof(int)的值是2,如果希望将常量-70 000正确地保存在一个变量a中,该变量声明语句应当是(B )。

A.int a; B.long int a; C.unsigned int a; D.unsigned int a;

5.以下声明语句中,用于声明一个行指针变量的是(C )。

A.int *p(int); B.int *p; C.int (*p)[3]; D.int (*p)(int);

6.在以下程序中,需要在fun函数中声明一个int型的变量,以下选项中(A )不能用做该变量的名字。

#include

int y;

main( )

{ int a=1;

fun(a);

}

int fun(int x)

{_______; /*int型变量声明语句位置*/

… /*若干执行语句*/

}

A.x B.y C.fabs D.fun

7.如有语句“int x,y=0,z,*p[3]; p[0]=&x; p[1]=&y; p[2]=&z;”,以下表达式中有语法错误的是(B )。

A.y++ B.p++ C.*++p[0] D.(*p[0])++

8.设有声明语句“int a[3][3]={1,2,3,4,5,6,7,8,9};”,以下语句中除(D )外均能输出a[1][2]的值。

A.printf("%d ",*(*(a+1)+2)) B.printf("%d ",*(&a[2][0]-1));

C.printf("%d ",*(a[1]+2)); D.printf("%d ",*(a+1)[2]);

9.已知有声明语句int x=8,则下列表达式中,值为2的是(B )。

A.x+=x-=x B.x% = x-2 C.x>8?x=0:x++ D.x/= x + x

10.以下关于函数的叙述中正确的是(D )。

A.在函数体中可以直接引用另一个函数中声明为static类别的局部变量的值

B.在函数体中至少必须有一个return语句

C.在函数体中可以定义另一个函数

D.在函数体中可以调用函数自身

11.若有声明语句“int a[10], b[3][3];”,则以下对数组元素赋值的操作中,不会出现越界访问的是(D )。

A.a[-1]=0 B.a[10]=0 C.b[3][0]=0 D.b[0][2]=0

12.若有声明语句“char ch=’a’, *pc=&ch;”,以下语句中有语法错误的是(C )。

A.(*pc)++; B.ch+= -‘a’ + ‘A’;

C.toupper(ch)=ch; D.ch++;

13.已知有声明语句“int a[5]={1, 2, 3, 4, 5}, *p, i;”,以下语句中(C )不能正确输出a数组全部元素的值。

A.for(p=a, i=0;i<5;i++)printf("%d",*(p+i));

B.for(p=a;p

C.for(p=a, i=0;p

D.for(p=a;p

14.已知某程序如下:

float p=1.5;

#define p 2.5

main( )

{printf("%f", p);}

则main函数中标识符p代表的操作数是(D )。

A.float型变量B.double型变量

C.float型常量D.double型常量

15.已有声明“int S[2][3]”,以下选项中(A )正确地引用了数组S中的基本元素。

A.S[1>2][!1] B.S[2][0] C.S[1] D.S

16.逻辑“异或”运算可描述为“a xor b”,其中a和b为参加运算的两个操作数,运算结果为当且仅当a、b两个操作数中只有一个为真时才为真,其他情况下均为假。以下表达式中(D )可以正确表示逻辑“异或”运算。

A.a || b B.a && b C.(a&&b)&&!(a || b) D.(a || b)&&!(a&&b) 17.若有声明“int a[5],*b=a,(*c)[3],*d[3];”,则在以下表达式中有语法错误的是(C )。A.a[0]=0 B.b[0]=0 C.c[0]=0 D.d[0]=0

18.若有声明:

int k, a, b;

unsigned long y=5;

double x=1.23;

则以下表达式中正确的是(D )。

A.x%(-5) B.x=y[6] C.k=(a=1,b=2,&a + &b) D.a+=a- = (b=2) * (a = 3) 19.一个用C语言编写的源程序中,(A )是必不可少的。

A.取名为main的函数定义B.#include

C.变量声明D.注释

20.以下声明中正确的是(D )。

A.int n=2, a[n]={10}; B.int n=10, *p[2]=&n;

C.int n=10, a[2]={n}; D.int a[2][2]={10}, (*p)[2]=a+1;

21、若有函数fun的定义为

void fun(…)

{static int a=1;

}

则下列叙述中不正确的是(B )。

A.在每次调用fun函数时,变量a的值是上次调用结束时a的值

B.在fun函数之外,可以用变量名a直接引用a的值

C.在其他函数中,可以出现声明double a=2.5;

D.fun函数的形式参数不能取名为a

22.以下单目运算符均只需要一个操作数,其中要求操作数的类型只能是指针型的是(D )。

A.& B.++ C.! D.*

23.已知有声明“int good=l; ”,若要使得表达式“p="good"+good”无语法错误(包括警告错误),p应当声明为(B )。

A.char p; B.char*p; C.int p; D.int *p;

24.以下全局变量声明中正确的是(D )。

A.auto int i=1; B.float a=1, b=0.5, c=a+b;

C.char for=1; D.static char ch;

25.若已有声明“double a[2][3]={1, 2, 3, 4, 5, 6};”,则下列表达式中不能正确引用a[1][1]值的是(C )。

A.*(a[0]+4)

B.*(a[1]+1)

C.*(*(a+3)+1)

D.*(*a+4)

26、已有声明“int a[5];”,以下表达式中不能正确取得a[1]指针的是(B )。

A.&a[1]

B.++a

C.&a[0]+1

D.a+l

27.以下关于语句的说法中正确的是(A )。

A.do-while语句的循环体至少会被执行1次

B.while语句的循环体至少会被执行1次

C.for语句的循环体至少会被执行1次

D.在C语言中只能用do、do-while或for语句实现循环结构

28.已知函数f的定义如下:

void f(void)

{printf("That’s great! ");}

则调用f函数的正确形式是(B )。

A.f;

B.f();

C.f(void);

D.f(1);

29.以下程序在编译时在第三行报错“Redeclaration of ‘a’in function d”,如果决定修改该行声明中出现的局部变量a的名字,则下列选项中不能用来替换变量名a的是(A )。

int b;

void d(int a)

{ int f; double a=1;

printf("%d",a);

}

main( )

{int e=1;d(e);}

A.f B.e C.d D.b

30、以下语句中不包含关键字的是(A )。

A.x=sqrt(2);

B.while(x!=0)x--;

C.if(x<0)x=-x;

D.return x;

31.在main函数体内部和外部均允许出现的实体是(B )。

A.预处理命令

B.语句

C.另一函数的定义

D.函数形式参数声明

32、已知有声明int x=2:,以下表达式中值不等于8的是(D )。

A.x+=2,x*2

B.x+=x*=X

C.(x+7)/2*((x+1)%2+1)

D.x*7.2/x+1

33、执行以下程序时,

#include

main()

{ int a; float b;

scanf("%3d%f",&a,&b);printf("%d\t%f",ab);

}

若要求变量a和b分别从键盘获得输入值45和678.0,则以下四种输入数据中( 代表“空格”键,代表“回车”键),不能达到该要求的输入数据是(C )。

A.45 678

B.45678

C.45,678

D.045678

34.下列程序段中,能将变量x、y中值较大的数保存到变量a、值较小的数保存到变量b 的程序段是(C )。

A.if(x>y)a=x;b=y;else a=y;b=x;

B.if(x>y){a=x;b=y;}else a=y;b=x;

C.if(x>y){a=x;b=y;}else{a=y;b=x;}

D.if(x>y){a=x;b=y;}else(x

35.已知函数fun的定义如下:

void fun(int x[], int y)

{ int k;

for(k=0;k

x[k]+=y;

}

若main函数中有声明int a[10]={10}及调用fun函数的语句,则正确的fun函数调用形式是(C )。

A.fun(a[ ],a[0]);

B.fun(a[0],a[0]);

C.fun(&a[0],a[0]);

D.fun(a[0],&a[0]);

36.设有下列程序段:

static char b=2;

void Y ( )

{ static float d=4;……}

int a=1;

void X ( )

{ int c=3;……}

关于程序段中各变量的属性,以下叙述中错误的是(D )。

A.a是全局变量,函数X可以访问,函数Y不能访问

B.b是全局变量,函数X和函数Y都可以访问

C.c是动态变量,函数X可访问,函数Y不可访问

D.d是静态变量,函数X和函数Y都可以访问

37、若有如下声明和语句:

int t[3][3], *pt[3], k;

for(k=0; k<3;k++) pt[k]=&t[k][0];

则表达式*(*(pt+1)+2)所引用的是(C )。

A.t[2][0] B.&t[2][0] C.t[1][2] D.&t[1][2]

38.设有声明float a=1.23456; int i;,欲将a中的数值保留小数点后两位,第三位进行四舍五入运算,能实现该功能的表达式是(A )。

A.i=a*100+0.5, a=i/100.0 B.a=(a*100+0.5)/100.0

C.a=((int)a*100+0.5)/l00.0 D.a=(a/100+0.5)/100.0

39.若已有声明“int x=4, y=3;”,则表达式x < y ? x++: y++的值是(B )。

A.2 B.3 C.4 D.5

40.设有变量声明“char c;”, 执行“for (; c=(getchar( ) !=’\n’) ; )printf("%c", c); ”时,从键盘上输入“ABCDEFG↙”之后,输出的结果是(C )。

A.ABCDEFG B.AABBCCDDEEFFGG

C.非字母数字字符D.语句不能执行

41.以下表示数学式“a

A.a=b)&&!(b>=c) D.!(a>=b||b>=c) 42.下面关于循环语句for、while、do_while的叙述中,正确的是(D )。

A.三种循环语句的循环体都必须放入一对花括号中

B.三种循环语句中都可以缺省循环终止条件表达式

C.三种循环语句的循环体都至少被无条件地执行一次

D.三种循环语句都可能出现无穷循环

43、若有声明“int a[]={l, 2, 3, 4}, *p, i;”,则以下程序段中不能输出13的是(B )。

A.for(i=0;i<4;i+=2)printf("%d", a[i]);

B.for(p=0;p<4;p+=2)printf("%d", a[p]);

C.for(p=a;p

D.for(p=a, i=0; i<4;i+=2)printf("%d", p[i]);

44、下列叙述中正确的是(C )。

A.main函数必须出现在其他函数之前

B.main函数中至少必须有一条语句

C.C程序总是从main函数的第一条语句开始执行

D.C程序总是在执行完main函数的最后一条语句后结束

45.已知有结构定义和变量声明如下:

struct student

{ char name[20];

int score;

struct student *h;

}stu, *p; int *q;

以下选项中错误的是(C )。

A.p=&stu; B.q=&stu.score; C.scanf("%s%d", &stu); D.stu.h=p;

46、设有声明“int p[10]={1, 2}, i=0;”,以下语句中与“p[i]=p[i+1], i++;”等价的是(D )。

A.p[i]=p[i+1]; B.p[++i]=p[i]; C.p[++i]=p[i+1]; D.i++, p[i-1]=p[i]; 47.设有结构定义及变量声明如下:

struct product

{ char[5];

floadt price;

}y[4]={ "100", 100};

以下表达式中错误的是(D )。

A.(*y).code[0]=’2’;B.y[0].code[0]=’2’C.y->price=10; D.(*y)->price=10; 48.若有声明“int a=3, b=4, c=5;”,则下列表达式中值为0的是(D )。

A.a&&b=0 B.a<=b C.a||b&&c D.!(!c||1)

49.已知有声明“long x, y;”,且x中整数的十进制表示有n位数字(4

A.y=x/(10*(n-1))

B.y=x%(10*(n-1))

C.y=x%(long)pow(10, n-1)

D.y=x%(10^(n-1))

50.已知有声明“int x, y;”,若要求编写一段程序实现“当x大于等于0时y取值1,否则y 取值-1”,则以下程序段中错误的是(C )。

A.if(x>=0)y=1; else y=-1;

B.y=x>=0?1:01;

C.switch()

{case x>=0:y=1; break;

default:y=-1;

}

D.switch(x-abs(x))

{ case 0:y=1; break;

default:y=-1;

}

51、已知有声明“int m[]={5,4,3,2,1},i=0;”,下列对m数组元素的引用中,错误的是(B )。

A.m[++i]

B.m[5]

C.m[2*2]=0

D.m[m[4]]

52、若函数调用时的实参为变量,则以下关于函数形参和实参的叙述中正确的是(D )。

A.实参和其对应的形参占用同一存储单元

B.形参不占用存储单元

C.同名的实参和形参占用同一存储单元

D.形参和实参占用不同的存储单元

53.C语言规定,在一个源程序中main函数的位置(D )。

A.必须在最开始

B.必须在最后

C.必须在预处理命令的后面

D.可以在其他函数之前或之后

54、已知有声明“int a=3, b=4, c;”,则执行语句“c=1/2*(a+b);”后,c的值是(A )。

A.0

B.3

C.3.5

D.4

55、已知字母A的ASCII码是65,字母a的ASCII码是97,变量c中存储了一个大写字母的编码。若要求将c中大写字母编码转换成对应小写字母编码,则以下表达式中不能实现该功能的是(D )。

A.c=tolower(c)

B.c=c+32

C.c=c-‘A’+’a’

D.c= (c +’A’)%26-‘a’

56.已知有定义和声明:

struct student

{ int no;

char name[20];

struct {int year, month, day;}birth;

}s;

若要求将日期“1989年11月12日”保存到变量s的birth成员中,则能实现这一功能的程序段是(D )。

A.year=1989; month=11; day=12;

B.s.year=1989;s.month=11; s.day=12;

C.birth.year=1989; birth.month=11; birth.day=12;

D.s.birth.year=1989; s.birth.month=11; s.birth.day=12;

57、执行以下程序后的结果是(C )。

#include

void main()

{ int x=3;

Do

{

printf("%d\t", x=x-3);

}while(!x);

}

A.输出一个数:0

B.输出一个数:3

C.输出两个数:0和-3

D.无限循环,反复输出数

58.设有声明“int a=4, b=3, c=5;”,以下4个程序段中有3个程序段的执行效果是相同的,另一个执行效果不同的是(C )。

A.if(a>b) c=a, a=b, b=c;

B.if(a>b) {c=a, a=b, b=c;}

C.if(a>b) c=a; a=b; b=c;

D.if(a>b) {c=a; a=b; b=c;}

59、以下关于if语句和switch语句的叙述中错误的是(D )。

A.if语句和switch语句都可以实现算法的选择结构

B.if语句和switch语句都能实现多路(两路以上)选择

C.if语句可以嵌套使用

D.switch语句不能嵌套使用

60.若有声明语句“char s1[10]={0},s2[10]= "books";”,则能将字符串"books"赋给数组s1保存的表达式是(D )。

A.s1= "books"; B.strcpy(s2, s1);

C.s1=s2; D.strcat(sl, s2);

61.已知A盘根目录下的一个文本数据文件data.dat中存储了100个int型数据,若需要修改该文件中已经存在的若干个数据的值,只能调用一次fopen函数,已有声明语句“FILE *fp;”,则fopen函数的正确调用形式是(A )。

A.fp=fopen("a:\\data.dat","r+");

B.fp=fopen("a:\\data.dat ","w+");

C.fp=fopen("a:\\data.dat","a+ ");

D.fp=fopen("a:\\data.dat","w ");

62.数组和链表都可以用于存储一组彼此有关联的数据,以下说法中不正确的是(B )。A.数组占用一块连续的存储区域,链表可能占用若干块不连续的存储区域

B.数组和链表所占用的存储区域均不能在程序运行期间动态地分配

C.数组中的数据可以随机存取或顺序存取,链表中的数据只能顺序存取

D.数组的长度是固定的,链表的长度是不固定的

63.设有定义和声明语句:

typedef struct dtype

{int a;

struct dtype *b;

}node;

static node x[3]={5, &x[1], 7, &x[2], 9, ’\0’}, *prt=&x[0];

下列选项中,表达式值不为5的是(A )。

A.x[1].b->a-2

B.Ptr->b->a-2

C.(ptr+1)->a-2

D.ptr->a

64.在以下程序中,需要在main函数之后定义一个函数,以下选项中(D )可以用做该函数的名字。

#define P 3.14

int y;

main( )

{ int a = 1;

函数名(a);

… /*若干执行语句*/

}

int函数名(int x)

{return x*x;}

A.main B.y C.P D.print

65.已知有语句“FILE *fp;int x=123;fp =fopen("out.dat", "w");”,如果需要将变量x的值以文本形式保存到一个磁盘文件out.dat中,则以下函数调用形式中正确的是(B )。A.fprintf("%d", x); B.fprintf(fp, "%d", x);

C.fprinff("%d", x, fp); D.fprintf("out.dat", "%d", x);

66.已知有声明语句“char s1[10]= "12345", s2[10]= "abcde", s3[10];”,以下语句中能将s1中存储的字符串和s2中存储的字符串正确交换的是(D )。

A.s3=s1,s1= s2, s2 = s3;

B.s3[0] = s1[0],s1[0] = s2[0],s2[0]=s3[0];

C.strcpy(s3[0],s1[0]),strcpy(s1[0],s2[0]),strcpy(s2[0],s3[0]);

D.strcpy(s3,s1), strcpy(sl, s2), strcpy(s2, s3);

67.在定义任何一个函数时,下列选项中(B )是不可缺少的。

A.函数名之前的数据类型B.函数名之后的一对圆括号

C.形式参数声明D.函数体中的语句

68.已有数据类型定义和变量声明如下:

struct person

{int num;

char name[20], sex;

struct {int class; char prof[20];}in;

}a={20,"Li ning",’M’, {5,"computer"}}, *p= & a;

下列语句中正确的是(B )。

A.printf("%s", a->nname); B.printf("%s", p->in.prof);

C.printf("%s", *https://www.sodocs.net/doc/dc438763.html,); D.printf("%c", p->in->prof);

69.若有以下程序:

int x;

int f(int y)

{return标识符;}

# include

int w;

main( )

{int z=2;f(z);…}

则在函数f中return语句后允许出现的标识符是(B )。

A.x或w B.x或y C.z或w D.NULL

70.以下跳转语句中,只有(C )可以选择不唯一的跳转目的地。

A.continue; B.break; C.goto标识符; D.return;

71.在缺省情况下,标准C的编译系统中预定义的标准输出流stdout直接连接的设备是(D )。A.软盘B.硬盘C.键盘D.显示器

72.已有枚举类型定义:“enum letter{A, B, C=7, D, E};”,以下表达式中除(D )外,其他表达式的机内值均等于10。

A.’\xb’-1 B.B+E C.010+2 D.0xf-3

73.已知数据类型定义和变量声明如下:

struct sk

{int a; float b;}data[2], *p;

若有p=data,则以下对data[0]中成员a的引用中错误的是(A )。

A.data[0]->a B.data->a C.p->a D.(*p).a

74.已知有声明“char c=’1’; int x=300; float t=35000; double d=3.1234567e10;”,则以下表达式求值时除(D )外其结果都可能是不准确的。

A.x=t/c B.t=d/x C.t=d/1e5f D.t = x + c

75.已有预处理命令和声明如下:

#define N 10

int a=2, c=1;

double b=1.2;

下述程序段正确的是(C )。

A.switch(a)

{ case c: a--;break;

case c+1: a++;break;

}

B.switch(a)

{ case N>0: a=1;break;

case 1: a=0;break;

}

C.switch(a)

{ case 2: b++;break;

case ‘0’: b=3;

}

D.switch(b)

{ case 1.0: b++;break;

case 1.2: b=1;break;

}

76.若有以下声明和定义:

void fun(int c){printf("%d", c);}

main( )

{void (*a) (int)=fun, *b(int), (*c) ( int );

/*调用fun函数语句位置*/

}

void *b(int c){ }

如果在main函数中需要调用fun函数,以下调用语句中错误的是(C )。

A.fun(1); B.(*a)(1); C.b=fun; (*b)(1); D.c=a; (*c)(1);

77.以下叙述正确的是(A )。

A.一个用C语言编写的程序在运行时总是从main函数开始逐条执行语句的

B.main函数是系统库函数

C.main函数中每行只能出现一条语句

D.main函数必须出现在所有其他函数之前

78.以下关于函数形式参数的声明中正确的是(A )。

A.int a[ ]

B.int a [ ][ ]

C.int a[ ]={0}

D.int a[2][ ]

79.关于函数返回值,以下叙述中正确的是(B )。

A.函数返回值的类型由函数体内return语句包含的表达式的类型决定

B.函数返回值的类型由函数头部定义的函数类型决定

C.若函数体中有多个return语句,则函数的返回值是排列在最后面的return语句中表达式的值

D.若函数体内没有return语句,则函数没有返回值

80.已知字符A的机内编码为65,则执行下列函数调用语句时,不能输出字符B的是

(B )。

A.putchar(‘B’);

B.putchar("B");

C.putchar(66);

D.putchar(‘\x42’);

81.下列一维数组的声明中正确的是(C )。

A.int a[ ];

B.int n=10, a[n];

C.int a[10+1]={0};

D.int a[3]={1, 2, 3, 4};

82.已知有结构类型定义:

typedef struct ex{long int num;

char sex;

struct ex*next;

}student;

下列叙述错误的是(B )。

A.struct ex是结构类型

B.student是结构类型的变量名

C.ex可缺省

D.student不可缺省

83.下列程序段的输出结果是(C )。

int i, x[3][3]={9, 8, 7, 6, 5, 4, 3, 2, 1}, *p=&x[1][1];

for(i=0;i<4;i+=2)printf("%d", *(p+i));

A.5 2

B.5 1

C.5 3

D.9 7

84.已知有声明”char a[6], *p=a;”,现需要在程序运行过程中将字符串"Hello",保存到a数组中,则下列选项中能正确完成此操作的表达式是(D )。

A.a[6]="Hello"

B.a="Hello"

C.p="Hello"

D.strcpy(a, "Hello")

85.若要使表达式“p++”无语法错误,则变量p不能声明为(D )。

A.int p;

B.double p;

C.int *p;

D.struct{int x;}p;

86.以下函数定义中正确的是(C )。

A.int fun(int a, b){ }

B.int fun(int a[][]){}

C.int fun(void){}

D.int fun(static int a, int b){}

87.已知有函数f的定义如下:

int f(int a, int b)

{ if(a

在main函数中若调用函数f(2, 3),得到的返回值是(B )。

A.2

B.3

C.2和3

D.3和2

88.下列各选项都是在C语言程字段中增加的注释,其中注释方法错误的是(B )。

A.void main(/*int argc, char, *argv[ ]*/)

{ }

B.void main( )

{pri/*remark*/ntf("name");}

C.void main( )

{ int x/*=10*/;

printf("%d", x);

}

D.void main( )

{ int x=10;

/*printf(" %d", x);*/

}

89.若有定义和声明typedef enum{green, red, yellow, blue, b1ack}color; color flower;,则下列语句中正确的是(B )。

A.green=red;

B.flower=red;

C.color=red;

D.enum=red;

90.若已定义一个有返回值的函数,则以下关于调用该函数的叙述中错误的是(D )。A.函数调用可以作为独立的语句存在

B.函数调用可以出现在表达式中

C.函数调用可以作为一个函数实参

D.函数调用可以作为一个函数形参

91.对应main函数中的fun函数调用语句,以下给出的四个fun函数首部中,错误的是(D )。

main( )

{ int a[50], n;

fun(n, &a[9]);

}

A.void fun(int m, int x[])

B.void fun(int s, int h[41])

C.void fun(int p, int *s)

D.void fun(int n, int a)

92.若有声明“int i; float x; char a [50]; ”,为使i得到值1,x得到值3.1416,a得到值yz,当执行语句“scanf("%3d%f%2s", &i, &x, a);”时,正确的输入形式是(C )。

A.1, 3.1416, yz↙

B.13.1416yz↙

C.001 3.1416 yz↙

D.i=001, x=3.1416,a=yz↙

93.程序段“int x=3; do{printf("%d", x--); }while(!x);”的执行结果是(C )。

A.3 2 1

B.2

C.3

D.死循环

94.假定已有声明“char a[30], *p=a;”,则下列语句中能将字符串“This is a C program.”正确地保存到数组a中的语句是(D )。

A.a[30]= "This is a C program.";

B.a="This is a C program.";

C.p="This is a C program.";

D.strcpy(p, "This is a C program.");

95.若需要对一个数据文件abc.txt中的数据做加密处理并且限定只能做一次打开文件操作,则在“fp=fopen("abc.txt", 模式字符串);”中,模式字符串应当是(B )。

A."w+"

B."r+"

C."a+"

D."r"

96.下列在C语言源程序的错误中,通常不能在编译时发现的是(C )。

A.括号不匹配

B.非法标识符

C.数组元素下标值越界

D.程序结构不完整

97.若有程序段“char c=256; int a=c;”,则执行该程序段后a的值是(C )。

A.256

B.65536

C.0

D.-1

98.若有枚举类型定义“enum list1{x1, x2, x3, x4=6, x5, x6};”,则枚举常量x2和x6代表的值分别是(B )。

A.1,6

B.1,8

C.2,6

D.2,8

99.若程序中已有相应的声明,下列语句中错误的是(D )。

A.printf(i==4? "%6d\n":"%6d", i);

B.i==4 ? printf("%6d\n", i):printf("%6d", i);

C.for(i=10; ; i--)if(i==1)break;

D.for(i=10; ;)if(i--);break;

100.已知有声明“char a[ ]= "It is mine", *p="It is mine";”,下列叙述中错误的是(B )。

A.strcpy(a, "yes")和strcpy(p, "yes")都是正确的

B.a="yes"和p="yes"都是正确的

C.*a等于*p

D.sizeof(a)不等于sizeof(p)

C语言练习试题和答案

单项选择题: 1.(A)是构成C语言程序的基本单位。 A、函数 B、过程 C、子程序 D、子例程 2.C语言程序从 C开始执行。 A) 程序中第一条可执行语句 B) 程序中第一个函数 C) 程序中的main函数 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.下列正确的标识符是(C)。 [i] t 6.下列C语言用户标识符中合法的是( B)。 A)3ax B)x C)case D)-e2 E)union 7.下列四组选项中,正确的C语言标识符是(C)。 A) %x B) a+b C) a123 D) 123 8、下列四组字符串中都可以用作C语言程序中的标识符的是(A)。 A、print _3d db8 aBc B、I\am one_half start$it 3pai C、str_1 Cpp pow while D、Pxq My->book line# 语言中的简单数据类型包括(D)。 A、整型、实型、逻辑型 B、整型、实型、逻辑型、字符型 C、整型、字符型、逻辑型 D、整型、实型、字符型 10.在C语言程序中,表达式5%2的结果是C。 A) B)2 C)1 D)3 11.如果int a=3,b=4;则条件表达式"a

C语言选择题题库

C语言程序设计题库说明 一本题库适用对象 计算机应用技术计算机软件软件技术计算机网络技术与计算机控制技术等专业 二本题库包含有175道选择题 三本题库所有题目均附有答案

一、选择题 下列各题ABCD四个选项中,只有一个选项是正确的,请将正确选项涂在答题卡的相应位置上,答在试卷上不得分。 1、不合法的整数是()。 A)0x35 B)43.6 C)0532 D)-346 2、下列合法的字符常量是()。 A)“f” B)x C)65 D)‘\Xab’ 3、设有整型变量x,单精度变量y=,表达式x=float(y*3+((int)y%4))执行后,x的值为()。 A)17 B)17.500000 C) D) 4、在C语言中,负整数在内存中以()形式释放。 A)补码 B)BCD码 C)反码 D)十进制数 5、在C语言中,要求参加运算的数必须是整数的运算符是()。 A)/ B)!C)% D)= = 6、()是C语言中非法的数据类型关键字。 A)float B)singed C)integer D)Char

7、现已定义整形变量int i=1;执行循环语句while(i++<5);后i的值为()。 A)1 B)5 C)6 D)以上三个答案都不正确 8、下列语句的输出结果是()。 printf(“%f\n”,(float)(2+4)/2); A)有语法错误不能通过编译 B)3 C)D) 9、C语言中,整数-8在内存中的存储形式是()。 A)1111,1111,1111,1000 B)1000,0000,0000,1000 C)0000,0000,0000,1000 D)1111,1111,1111,0111 10、设C语言中,int类型数据占2个字节,则long类型数据占()个字节。 A)1 B)2 C)8 D)4 11、若变量a已说明为float类型,则能实现将a中的数值保留小数点后两位,第三位进行四舍五入运算的表达式是()。 A)a=(a*100+/ B)a=(a*100+/100 C)a=(int)(a*100+/ D)a=(a/100+*

C语言基本选择题及参考答案

C语言基本选择题及参考 答案 The pony was revised in January 2021

计算机程序设计基础(C语言) 单项选择练习题 一、基本概念 1.C语言程序是由C构成的。 A)一些可执行语言B)main函数C)函数D)包含文件中的第一个函数2.(A)是构成C语言程序的基本单位。 A、函数 B、过程 C、子程序 D、子例程 3.C语言程序从C开始执行。 A)程序中第一条可执行语句?B)程序中第一个函数 C)程序中的main函数?D)包含文件中的第一个函数 4.C语言程序从main()函数开始执行,所以这个函数要写在_D___。 A)程序文件的开始B)程序文件的最后 C)它所调用的函数的前面D)程序文件的任何位置 5、以下说法中正确的是(C)。 A、C语言程序总是从第一个定义的函数开始执行 B、在C语言程序中,要调用的函数必须在main()函数中定义

C、C语言程序总是从main()函数开始执行 D、C语言程序中的main()函数必须放在程序的开始部分 6.下列方法中错误的是(D)。 A.主函数可以分为两个部分:主函数说明部分和主函数体。 B.主函数可以调用任何非主函数的其它函数。 C.任何非主函数可以调用其它任何非主函数。 D.程序可以从任何非主函数开始执行。 7.下列说法错误的是:(B) A.C程序运行步骤是编辑、编译、连接、执行。 B.C语言的变量名必须用小写,常量用大写。 C.C语言的三种基本结构是顺序、选择、循环。 D.C程序一定由函数构成的。 8.下列关于C语言的说法错误的是(B)。 A)C程序的工作过程是编辑、编译、连接、运行 B)C语言不区分大小写。 C)C程序的三种基本结构是顺序、选择、循环

函数练习题(C语言)带答案

C语言函数练习题 一、选择题 1. 一个完整的C源程序是【】。 A)要由一个主函数或一个以上的非主函数构成 B)由一个且仅由一个主函数和零个以上的非主函数构成 C)要由一个主函数和一个以上的非主函数构成 D)由一个且只有一个主函数或多个非主函数构成 2. 以下关于函数的叙述中正确的是【】。 A)C语言程序将从源程序中第一个函数开始执行 B )可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行 C)C语言规定必须用main作为主函数名,程序将从此开始执行,在此结束 D)m ain可作为用户标识符,用以定义任意一个函数 3. 以下关于函数的叙述中不正确的是【】。 A)C程序是函数的集合,包括标准库函数和用户自定义函数 B)在C语言程序中,被调用的函数必须在main函数中定义 C)在C语言程序中,函数的定义不能嵌套 D)在C语言程序中,函数的调用可以嵌套 4. 在一个C程序中,【】。 A)main函数必须出现在所有函数之前 B)main函数可以在任何地方出现 C)m ain函数必须出现在所有函数之后 D)m ain函数必须出现在固定位置 5. 若在C语言中未说明函数的类型,则系统默认该函数的数据类型是【】 A)float B)long C)int D)double 6. 以下关于函数叙述中,错误的是【】。 A)函数未被调用时,系统将不为形参分配内存单元 B)实参与形参的个数应相等,且实参与形参的类型必须对应一致 C)当形参是变量时,实参可以是常量、变量或表达式 D )形参可以是常量、变量或表达式 7. 若函数调用时参数为基本数据类型的变量,以下叙述正确的是【】。 A)实参与其对应的形参共占存储单元 B)只有当实参与其对应的形参同名时才共占存储单元 C)实参与对应的形参分别占用不同的存储单元 D)实参将数据传递给形参后,立即释放原先占用的存储单元 9. 函数调用时,当实参和形参都是简单变量时,他们之间数据传递的过程是【】。 A)实参将其地址传递给形参,并释放原先占用的存储单元 B)实参将其地址传递给形参,调用结束时形参再将其地址回传给实参 C)实参将其值传递给形参,调用结束时形参再将其值回传给实参

c语言试题及答案

1、以下正确的说法是( B ) (A) 用户若需要调用标准库函数,调用前必须重新定义 (B) 用户可以重新定义标准库函数,若如此,该函数将失去原有含义 (C) 系统根本不允许用户重新定义标准库函数 (D) 用户若需调用标准库函数,调用前不必使用预编译命令将该函数所在文件包括到用户源文件中,系统自动去调 2、以下正确的函数声明形式是( A ) (A) double fun(int x, int y) (B) double fun(int x; int y) (C) double fun(int x, int y); (D) double fun(int x,y); 3、以下正确的函数形式是( D ) (A) double fun(int x, int y) { z=x+y; return z;} (B) fun(int x,y) { int z; return z;} (C) fun(x,y) { int x,y; double z; z=x+y; return z;} (D) double fun(int x, int y) { double z; z=x+y; return z;} 4、以下正确的说法是( A ) 在C语言中 (A) 实参和与其对应的形参各占用独立的存储单元 (B) 实参和与其对应的形参共占用一个存储单元 (C) 只有当实参和与其对应的形参同名时才共占用存储单元 (D) 形参是虚拟的,不占用存储单元 5、若调用一个函数,且此函数中没有return语句,则正确的说法是( A ) 该函数 (A) 没有返回值 (B) 返回若干个系统默认值 (C) 能返回一个用户所希望的函数值 (D) 返回一个不确定的值 6、以下不正确的说法是( B ) C语言规定 (A) 实参可以是常量、变量和表达式 (B) 形参可以是常量、变量和表达式 (C) 实参可以为任意类型 (D) 形参应与其对应的实参类型一致 7、以下正确的说法是( C ) (A) 定义函数时,形参的类型说明可以放在函数体内 (B) return后边的值不能为表达式 (C) 如果函数值的类型与返回值类型不一致,以函数值类型为准 (D) 如果形参与实参的类型不一致,以实参类型为准 8、C语言规定,简单变量做实参时,它和对应形参之间的数据传递方式是( B ) (A) 地址传递 (B) 单向值传递 (C) 由实参传给形参,再由形参传回给实参 (D) 由用户指定传递方式

C语言题库_选择题(1)

本卷共有4道大 一、单项选择题(25道小题,共50分) 1、以下说法中正确的是(C)(2分) A、C语言程序总是从第一个的函数开始执行 B、在C语言程序中,要调用的函数必须在main()函数中定义 C、C语言程序总是从main()函数开始执行 D、C语言程序中的main()函数必须放在程序的开始部分 2、一个算法应该具有“确定性”等五个特性,下面对另外4个特性的描述中错误的是(B)(2分) A、有零个或多个输入 B、有零个或多个输出 C、有穷性 D、可行性 3、以下选项中,不合法常量的是(B)(2分) A、1.234e04 B、1.234e0.4 C、1.234e+4 D、1.234e0 4、C语言中最简单的数据类型包括(B)(2分) A、整型、实型、逻辑型 B、整型、实型、字符型 C、整型、字符型、逻辑型 D、整型、实型、逻辑型、字符型 5、能正确表示逻辑关系:“10≥=a≥=0”的C语言表达式是(D)(2分) A、10>=a>=0 B、a>=0 and a<=10 C、a>=0||a<=10 D、a>=0&&a<=10 6、设a和b均为double型变量,且a=5.5、b=2.5,则表达式(int)a+b/b的值是(D)(2分)A、6.500000B、6 C、5.500000 D、6.000000

7、x、y、z被定义为int型变量,若从键盘给x、y、z输入数据,正确的输入语句是(B)(2分) A、INPUT x、y、z; B、scanf("%d%d%d",&x,&y,&z); C、scanf("%d%d%d",x,y,z); D、read("%d%d%d",&x,&y,&z); 8、设x和y均为int型变量,则以下语句:x+=y;y=x-y;x-=y;的功能是(D)(2分)A、把x和y按从大到小排列B、把x和y按从小到大排列 C、无确定结果 D、交换x和y中的值 9、若有以下程序段:int c1=1,c2=2,c3;c3=1.0/c2*c1;则执行后,c3中的值是(A)(2分)A、0B、0.5 C、1 D、2 10、设char ch='A';则ch=(ch>='A'&&ch<='Z')?(ch+32):ch的值是(B)。(2分) A、A B、a C、Z D、z 11、执行程序段int a=-1,b=4,k;k=(++a<0)&&!(b-- <=0);printf(“%d %d %d\n”,k,a,b);后的输出结果是(D )。 (2分) A、1 0 4 B、1 0 3 C、0 0 3 D、0 0 4 12、设intx=1, y=1;表达式(!x||y--)的值是(B)。(2分) A、0B、1 C、2 D、-1 13、程序段intx=3;do{printf(“%d”,x-=2);}while(!(--x));的输出结果是(C)。(2分) A、1 B、30 C、1-2 D、死循环

C语言基础练习100题(含答案)

C语言基础练习100题(含答案) 欧阳学文 雷柳青编排 1、下面程序的输出是________ #include void main() { int k=11; printf("k=%d,k=%o,k=%x\n",k,k,k); } A) k=11,k=12,k=11 B) k=11,k=13,k=13 C) k=11,k=013,k=0xb D) k=11,k=13,k=b 2、在下列选项中,不正确的赋值语句是________. A) ++t; B) n1=(n2=(n3=0)); C) k=i=j; D) a=b+c=1; 3、下面合法的C语言字符常量是__________. A) '\t' B) "A" C) 65 D) A 4、字符(char)型数据在微机内存中的存储形式是____. A) 反码B) 补码C) EBCDIC码D) ASCII码 5、设int a=12,则执行完语句a+=a=a*a 后,a的值是________ A) 552 B) 264 C) 144 D) 264 6、执行下面程序中的输出语句后,输出结果是______. #include void main() {int a; printf("%d\n",(a=3*5,a*4,a+5)); } A) 65 B) 20 C) 15 D) 10 7、下面程序的输出是__________. #include void main() {int x=023; printf("%d\n",x); } A) 17 B) 18 C) 23 D) 24 8、下面程序的输出是___________. #include void main() {char ch1,ch2; ch1='A'+'5''3'; ch2='A'+'6''3'; printf("%d,%c\n",ch1,ch2); } A) 67,D B) B,C C) C,D D) 不确定的值 9、以下程序的输出结果是________. #include void main() { int x=10,y=10; printf("%d %d\n",x,y); } A) 10 10 B) 9 9 C) 9 10 D) 10 9 10、若x和y都是int型变量,x=100,y=200,且有下面的程序片段: printf("%d",(x,y)); 上面程序片段的输出结果是_______.

C语言试卷及答案

一、选择题(每题 1 分,共 20 分) 1. C 语言程序的三种基本结构是顺序结构、选择结构和结构。 A、循环 B、递归 C、转移 D、嵌套 2. 下列标识符中,合法的是_______ 。 A) unsigned B) 5ab C) INT# D)_num2 3. 若float x ;x = 10/4 ;x的值是。 A、2.5 B、2.0 C、3 D、 2 4. 表达式!x 等价于。 A、x==0 B、x==1 C、x != 0 D、x != 1 5. 算术运算符、赋值运算符和关系运算符的运算优先级按从高到低的顺序依次为。 A、算术运算、赋值运算、关系运算 B、关系运算、赋值运算、算术运算 C、算术运算、关系运算、赋值运算 D、关系运算、算术运算、赋值运算 6. 能将高级语言编写的源程序转换为目标程序的是。 A、链接程序 B、解释程序 C、编译程序 D、编辑程序 7. 下列语句定义pf为指向float类型变量f的指针,是正确的。 A、float f, *pf = f; B、float f, *pf = &f; C、float *pf = &f, f; D、float f, pf = f; 8. 一个C程序的执行是从。 A、本程序的main函数开始,到main函数结束 B、本程序文件的第一个函数开始,到本程序文件的最后一个函数结束 C、本程序的main函数开始,到本程序文件的最后一个函数结束 D、本程序文件的第一个函数开始,到本程序main函数结束 9. 能正确表示“当x的取值在[1,10]或[[200,210]范围内为真,否则为假”的表达式是________。 A、(x>=1)&&(x<=10)&&(x>=200)&&(x<=210) B、(x>=1)||(x<=10)||(x>=200)||(x<=210) C、(x>=1)&&(x<=10)||(x>=200)&&(x<=210) D、(x>=1)||(x<=10)&&(x>=200)||(x<=210) 10. 对两个数组a和b进行如下初始化 char a[]=“ABCDEF”;char b[]={ …A?,?B?,?C?,?D?,?E?,?F?}; 则以下叙述正确的是。 A、a和b数组完全相同 B、a和b长度相同 C、a和b中都存放字符串 D、a数组比b数组长度长 11. 是不正确的字符常量。 A、'\n' B、'1' C、"a" D、'\101' 12. 若变量已正确定义,语句“if(a>b) k=0; else k=1;”和等价。 A、k=(a>b)?1:0; B、k=a>b; C、k=a<=b; D、a<=b ? 0 : 1; 13. 设变量定义为“int x, *p=&x;”,则&*p相当于。 A、p B、*p C、x D、*&x 14. 有两个字符数组a、b,则以下正确的输入语句是。 A)gets(a,b); B) scanf(“%s%s”,a,b); C) scanf(“%s%s”,&a,&b); D) gets(“a”),gets(“b”); 15. C语言规定,简单变量做实参时,它和对应形参之间的数据传递方式是。 A、地址传递 B、单向值传递

C语言程序设计期末考试选择题题库

第一章1、一个C程序可能出现的错误有(A)A,以上都包括 B,逻辑错误 C,运行错误 D,语法错误 2、C程序中一般可以包含几个函数(D) A.1个 B.多个 C.0个 D.至少一个 3.C语言属于程序设计语言的哪个类别(B) A.机器语言 B.高级语言 C.面向对象语言 D.汇编语言 4.以下关于C语言描述错误的是(B) A.一个C程序总是从main函数开始执行 B.一个C程序可以包含多个main函数 C.每个语句的最后必须有一个分号 D.C语言的注释符是以"/*"开始并以"*/"结束

5、在调试过程中,逻辑错误是指(C) A.所书写的语句,不符合C的语法。 B.在从obj生成exe文件的过程中,如果函数名书写错误,可能产生的错误。 C.程序的运行结果不符合题目要求。 D.在exe文件的执行过程中,产生运行异常。 第二章 1、16位的二进制数可以表示的整数的范围是(C) A.[-32768,32768] B.[-32767,32768] C.[-32768,32767] D.[-32767,32767] 2、C语言中的实型数据包括(A) A.float和double B.int和float C.float和char D.int和double 3、以下不合法的字符常量是(C) A.'2' B.'A' C.'ab'

4、在以下各组标识符中,均是合法的C语言标识符是(A) A.abc,A_4d,_student,xyz_abc B.auto,12-a,a_b,ab5.x C.A_4d,_student,xyz_abc,if D.abc,a_b,union,scan 5、若有定义:chara;intb;floatc;doubled; 则表达式a*b+d-c值的类型为(A) A.char B.float C.double D.int 6、类型修饰符unsigned不能修饰(D) A.char B.longint C.int D.float 7、若有定义:doublex=1,y; 执行语句,则y的值是(B) A,1 B,2.0

2020最新C语言考试题库及答案

精选考试类应用文档,如果您需要使用本文档,请点击下载,另外祝您生活愉快,工作顺利,万事如意! 精选考试类文档,如果需要,请下载,希望能帮助到你们! 2020最新C语言考试题库及答案

姓名成绩 温馨提示:同学们,经过培训学习,你一定积累了很多知识,现在请认真、仔细地完成这张试题吧。加油! 一单项选择题 1. 在C语言中,以 D 作为字符串结束标志 A)’\n’ B)’ ’ C) ’0’ D)’\0’ 2.下列数据中属于“字符串常量”的是( A )。 A.“a” B.{ABC} C.‘abc\0’ D.‘a’ 若干个字符构成字符串

在C语言中,用单引号标识字符;用双引号标识字符串 选项B,C,分别用{}和’’标识字符串 选项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.下列正确的标识符是(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) %x B) a+b C) a123 D) 123 8、下列四组字符串中都可以用作C语言程序中的标识符的是( A )。 A、print _3d db8 aBc B、I\am one_half start$it 3pai 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

(完整版)C语言试题及答案解析

C语言 一、选择题(第题2分,共20分) 1.一个C程序的执行是从 A 。 A) 本程序的main函数开始,到main函数结束 B) 本程序文件的第一个函数开始,到本程序文件的最后一个函数结束 C) 本程序文件的第一个函数开始,到本程序main函数结束 D) 本程序的main函数开始,到本程序文件的最后一个函数结束 2.若x、i、j、k都是int型变量,则计算下面表达式后,x的值为 C 。 x=(i=4,j=16,k=32) A) 4 B) 16 C) 32 D) 52 3.设C语言中,一个int型数据在内存中占2个字节,则unsigned int 型数据的取值范围为 C 。 A) 0~255 B) 0~32767 C) 0~65535 D) 0~2147483647 4.设有说明:char w; int x; float y; double z;则表达式w*x+z-y值的数据类型为 D 。 A) float B) char C) int D) double 5. putchar函数可以向终端输出一个 D 。 A) 整型变量表达式 B) 实型变量值 C) 字符串 D) 字符或字符型变量值 6. printf函数中用到格式符%5s,其中数字5表示输出的字符串占用5列。如果字符串长度大于5,则输出按方式 B ;如果字符串长度小于5,则输出按方式 C 。 A) 从左起输出该字符串,右补空格 B) 按原字符长从左向右全部输出 C) 右对齐输出该字符串,左补空格 D) 输出错误信息 7.判断char型变量ch是否为大写字母的正确表达式是 C 。 A) ‘A’<=ch<=‘Z’ B) (ch>=‘A’)&(ch<=‘Z’) C) (ch>=‘A’)&&(ch<=‘Z’) D) (‘A’<= ch)AND(‘Z’>= ch) 8.已知int x=10,y=20,z=30;以下语句执行后x,y,z的值是 B 。 if(x>y) z=x; x=y; y=z; A) x=10, y=20, z=30 B) x=20, y=30, z=30 C) x=20, y=30, z=10 D) x=20, y=30, z=20 9.以下程序段______C__. x=-1; do{ x=x*x; } while(!x); A)是死循环 B)循环执行二次 C)循环执行一次 D)有语法错误 10.以下正确的描述是___B____. A)continue语句的作用是结束整个循环的执行

C语言试题与答案

大学C语言考试题库 第1章 C语言概述习题 1. 单项选择题 (1) C 语言是在 B 语言的基础上产生的。 A. A B. B C. D D. E (2) 在 C 语言中,每个语句必须以 D 结束。 A. 回车符 B. 冒号 C. 逗号 D. 分号 (3) 标识符和关键字间,要用 C 隔开。 A. 回车符 B. 冒号 C. 空格 D. 分号 (4) 用 C 语言编写的源文件经过编译,若没有产生编译错误,则系统将( B )。 A. 生成可执行目标文件 B. 生成目标文件 C. 输出运行结果 D.自动保存源文件 (5) 下列说法中正确的是( B )。 A. 由于 C 源程序是高级语言程序,因此一定要在 TC 软件中输入 B. 由 C 源程序是字符流组成,因此可以作为文本文件在任何文本编辑的软件中输入 C. 由于C 程序是高级语言程序,因此输入后即可执行 D. 由于 C 程序是高级语言程序,因此它由命令组成 (6) 下列说法中正确的是( A )。 A. C 语言程序由主函数和 0 个或多个函数组成 B. C 语言程序由主程序和子程序组成 C. C 语言程序由子程序组成 D. C 语言程序由过程组成 (7) 下列说法中错误的是( D )。 A. 主函数可以分为两个部分:主函数说明部分和主函数体 B. 主函数可以调用任何非主函数的其他函数 C. 任何非主函数可以调用其他任何非主函数 D. 程序可以从任何非主函数开始执行 2. 填空题 (1) C 语言只有 32 个关键字和 9 种控制语句。 (2) C 语言是一种“中级语言”,既具有高级语言的特点又具有低级语言的特点;既适合于开发系

C语言选择题#精选.

1 C语言程序由函数组成,以下说法正确的是( A ). A)主函数可以在其它函数之前,函数内不可以嵌套定义函数 B)主函数可以在其它函数之前,函数内可以嵌套定义函数 C)主函数必须在其它函数之前,函数内不可以嵌套定义函数 D)主函数必须在其它函数之前,函数内可以嵌套定义函数 2 以下说法中不正确的是( A )。 A) 主函数main中定义的变量在整个文件或程序中有效 B) 不同的函数中可以使用相同名字的变量 C) 形式参数是局部变量 D) 在一个函数内部,可以在复合语句中定义变量,这些变量只在本复合语句中有效 3 下面函数 f(double x) {printf(“%6d\n”,x);} 的类型为( C ). A) 实型B)void 类型C)int 类型D) A)、B)、C)均不正确 4 以下说法中正确的是( C ). A)C语言程序总是从第一个定义的函数开始执行 B)在C语言程序中,要调用的函数必须在main函数中定义 C)C语言程序总是从main函数开始执行

D)C语言程序中,main函数必须放在程序的开始部分 5 以下正确的函数定义是( C ). A) double fun(int x,int y); {int z; z=x+y; return z;} B) fun(int x,y) {int z; return z;} C) double fun(int x,int y) {double z; z=x+y; return z;} D) double fun( x, y) {int x,y; double z; z=x+y; return z;} 6 定义为void类型的函数,其含义是( A ). A)调用函数后,被调用的函数没有返回值 B)调用函数后,被调用的函数不返回 C)调用函数后,被调用的函数的返回值为任意的类型D)以上三种说法都是错误的 7 设有如下定义: int x=10,y=3,z ; 则语句

c语言练习题带答案)-绝对经典题目不看后悔

1单选题 1.(A)是构成C语言程序的基本单位。 A、函数 B、过程 C、子程序 D、子例程 2.C语言程序从C开始执行。 A) 程序中第一条可执行语句B) 程序中第一个函数 C) 程序中的main函数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.下列正确的标识符是(C)。 A.-a1 B.a[i] C.a2_i D.int t 5~8题为相同类型题 考点:标识符的命名规则 (1)只能由字母、数字、下划线构成 (2)数字不能作为标识符的开头 (3)关键字不能作为标识符 选项A中的“-” ,选项B中“[”与“]”不满足(1);选项D中的int为关键字,不满足(3) 6.下列C语言用户标识符中合法的是(B)。 A)3ax B)x C)case D)-e2 E)union 选项A中的标识符以数字开头不满足(2);选项C,E均为为关键字,不满足(3);选项D中的“-”不满足(1); 7.下列四组选项中,正确的C语言标识符是(C)。 A)%x B)a+b C)a123 D)123 选项A中的“%” ,选项B中“+”不满足(1);选项D中的标识符以数字开头不满足(2) 8、下列四组字符串中都可以用作C语言程序中的标识符的是(A)。 A、print _3d db8 aBc B、I\am one_half start$it 3pai C、str_1 Cpp pow while D、Pxq My->book line# His.age 选项B中的“\”,”$” ,选项D中“>”,”#”,”.”,”-”不满足(1);选项C中的while为关键字,不满足(3) 9.C语言中的简单数据类型包括(D)。 A、整型、实型、逻辑型 B、整型、实型、逻辑型、字符型 C、整型、字符型、逻辑型 D、整型、实型、字符型 10.在C语言程序中,表达式5%2的结果是C。 A)2.5 B)2 C)1 D)3 详见教材P52~53.

C语言单项选择题

单项选择题(本大题共20小题,每小题1分,共20分) 1.C++源程序文件扩展名为(A) A..cpp B..h C..1ib D..obj 5.对使用关键字new所开辟的动态存储空间,释放时必须使用(C)A.free B.create C.delete D.realse 6.从本质上看,引用是被引用变量的(B) A.拷贝 B.别名 C.复制 D.克隆 7.在函数调用时,如某一默认参数要指明一个特定值,则有(B) A.其之前所有参数都必须赋值B.其之后所有参数都必须赋值 C.其前、后所有参数都必须赋值D.其前、后所有参数都不必赋值 8.设存在函数int max(int,int)返回两参数中较大值,若求22,59,70三者中最大值,下列表达式不正确的是(C) A.int m=max(22,max(59,70));B.int m=max(max(22,59),70); C.int m=max(22,59,70);D.int m=max(59,max(22,70)); 9.设存在函数int min(int,int)返回两参数中较小值,若求15,26,47三者中最小值,下列表达式中错误的是(B) A.int m=min(min(15,26),min(15,47)); B.int m=min(15,26,47); C.int m=min(15,min(47,26)); D.int m=min(min(47,26),16); 13.函数int&min(int&,int&)返回参数中较小者,设有两整型变量int a=10;int b=15; 在执行语句min(a,b)--;之后,a,b值分别为(B) A.9,14 B.9,15 C.10,14 D.10,15 16.设函数void swap(int&,int&)将交换两形参的值,如两整型变量int a=10;int b=15;则执行swap(a,b)后,a、b值分别为(C) A.10,10 B.10,15 C.15,10 D.15,15

C语言选择题复习精选.

选择题复习 1.表达式“(a=4*5, b=a*2), b-a, a+=2”的值是(C)。 A.2 B.20 C.22 D.42 2.以下是一个自定义函数的头部,其中正确的是(C )。 A.int fun(int a[ ], b) B.int fun(int a[ ], int a) C.int fun(int*a, int b) D.int fun(char a[ ][ ], int b) 3.以下数组声明语句中正确的是(D )。 A.int n, a[n]; B.int a[ ]; C.int a[2][3]={{l},{2},{3}}; D.int a[ ][3]={{l},{2},{3}}; 4.已知在某C语言编译系统中表达式sizeof(int)的值是2,如果希望将常量-70 000正确地保存在一个变量a中,该变量声明语句应当是(B )。 A.int a; B.long int a; C.unsigned int a; D.unsigned int a; 5.以下声明语句中,用于声明一个行指针变量的是(C )。 A.int *p(int); B.int *p; C.int (*p)[3]; D.int (*p)(int); 6.在以下程序中,需要在fun函数中声明一个int型的变量,以下选项中(A )不能用做该变量的名字。 #include int y; main( ) { int a=1; fun(a); } int fun(int x) {_______; /*int型变量声明语句位置*/ … /*若干执行语句*/ } A.x B.y C.fabs D.fun 7.如有语句“int x,y=0,z,*p[3]; p[0]=&x; p[1]=&y; p[2]=&z;”,以下表达式中有语法错误的是(B )。 A.y++ B.p++ C.*++p[0] D.(*p[0])++ 8.设有声明语句“int a[3][3]={1,2,3,4,5,6,7,8,9};”,以下语句中除(D )外均能输出a[1][2]的值。 A.printf("%d ",*(*(a+1)+2)) B.printf("%d ",*(&a[2][0]-1)); C.printf("%d ",*(a[1]+2)); D.printf("%d ",*(a+1)[2]); 9.已知有声明语句int x=8,则下列表达式中,值为2的是(B )。 A.x+=x-=x B.x% = x-2 C.x>8?x=0:x++ D.x/= x + x 10.以下关于函数的叙述中正确的是(D )。 A.在函数体中可以直接引用另一个函数中声明为static类别的局部变量的值 B.在函数体中至少必须有一个return语句 C.在函数体中可以定义另一个函数 D.在函数体中可以调用函数自身 11.若有声明语句“int a[10], b[3][3];”,则以下对数组元素赋值的操作中,不会出现越界访问的是(D )。 A.a[-1]=0 B.a[10]=0 C.b[3][0]=0 D.b[0][2]=0

C语言试题-选择题及答案

C语言试题 ★第1 题: 阅读程序,选择程序的运行结果___A___。 #include main() { int x; x=try(5); printf(“%d\n”, x); } try(int n) { if(n>0) return(n*try(n-2)); else return(1); } A. 15 B. 120 C. 1 D. 前面3个答案均是错误的 第2 题: 在下列结论中,只有一个是正确的,它是___A___。 A. 递归函数中的形式参数是自动变量 B. 递归函数中的形式参数是外部变量 C. 递归函数中的形式参数是静态变量 D. 递归函数中的形式参数可以根据需要自己定义存储类型 ★第3 题: 阅读程序,选择程序的输出结果__A___。 #include f(int x, int y) { return(y-x); } main() { int (*g)(int,int); int a=5, b=6, c=2; g=f; c=(*g)(a,b); printf(“%d\n”, c); } A. 1 B. 2 C. 3 D. 前面3个答案均是错误的 第4 题: 阅读程序,选择程序的输出结果__D___。 #include

char *p=”abcdefghijklmnopq”; main() { while(*p++!=?e?) ; printf(“%c\n”, *p); } A. c B. d C. e D. f ★第6 题: 阅读程序,选择程序的输出结果___D___。 #include void prtv(int *x) { printf(”%d\n”, ++*x); } main() { int a=25; prtv(&a); } A. 23 B. 24 C. 25 D. 26 第7 题: 阅读程序,选择程序的输出结果___B___。 #include main() { static char a[ ]= ”language”, b[]=”program”; char *ptr1=a, *ptr2=b; int k; for(k=0; k<7; k++) if(*(ptr1+k)==*(ptr2+k)) printf(”%c”, *(ptr1+k)); } A. gae B. ga C. language D. 有语法错误 ★第8 题: 函数调用strcat(strcpy(str1, str2), str3)的功能是__C___。 A. 将串str1复制到串str2中,然后再连接到str3之后 B. 将串str1连接到串str2之后,再复制到str3之中 C. 将串str2复制到串str1中,然后再将串str3连接到串str1之后

c语言试题及答案

《C语言》课程综合复习资料 一、单选题 1. 在C语言中,字符型数据在存中的存储形式是 A)原码 B)补码 C)反码 D)ASCII码 2. 在C语言中,十进制数47可等价地表示为 A) 2f B) 02f C) 57 D) 057 3. 设有定义:int x=12,n=5; 则表达式 x%=(n%2) 的值为 A) 0 B) 1 C) 2 D) 3 4. 设有定义语句:char str[][20]={,"Beijing","中国石油大学"},*p=str; 则printf("%d\n",strlen(p+20)); 输出结果是 A)10 B) 6 C) 0 D) 20 5. 已定义以下函数: fun(int *p) { return *p; } 该函数的返回值是 A)不确定的值 B)形参p所指存储单元中的值 C)形参p中存放的值 D)形参p的地址值 6. C语言中,函数返回值的类型是由 A)return语句中的表达式类型决定 B)调用函数的主调函数类型决定 C)调用函数时的临时类型决定 D)定义函数时所指定的函数类型决定 7. 有以下函数定义: void fun( int n , double x ) { …… } 若以下选项中的变量都已正确定义并赋值,则对函数fun的正确调用语句是 A) fun( int y , double m ); B) k=fun( 10 , 12.5 ); C) fun( 10 , 12.5 ); D) void fun( 10 , 12.5 ); 8. 以下选项中不能正确赋值的是 A) char b[]={′H′,′e′,′l′,′l′,′o′,′!′}; B) char b[10];b="Hello!";

c语言选择题及答案

1﹑以下选项中不合法的用户标识符是( C )。 A)_123 B)PP C)A$ D)Dim 2﹑C语言提供的合法数据关键字是( A )。 A)float B) Sagned C) Integer D) ing 3﹑判断char型变量c1是否为小写字母的正确表达式为( D )。 A) 'a'<=c1<='z' B) (c1>=A. &&(c1<='z') C) ('a'>=c1)||('z'<=c1) D) (c1>='a')&&(c1<='z') 4﹑C语言可执行程序开始执行点为( C ). A)程序中第一条可执行语句B) 程序中第一个函数 C)程序中的main函数D) 包含文件中的第一个函数 @ 5﹑以下说法中正确的是( C ). A)C语言程序总是从第一个定义的函数开始执行 B)在C语言程序中,要调用的函数必须在main函数中定义 C)C语言程序总是从main函数开始执行 D)C语言程序中,main函数必须放在程序的开始部分 6﹑设有定义:int a=1,b=2,c=3;,以下语句中执行效果与其它三个不同的是( C )。A)if(a>b) c=a,a=b,b=c; B)if(a>b) {c=a,a=b,b=c;} C)if(a>b) c=a;a=b;b=c; D)if(a>b) {c=a;a=b;b=c;} 7﹑若有说明和语句: int a=5,b; b=a++; 此处变量b的值是( C )。 A)7 B)6 C)5 D) 8﹑以下程序的输出结果是( D )。 ~ int x=10,y=10; printf("%d %d\n",x--,--y); A) 10 10 B) 9 9 C) 9 10 D) 10 9 9﹑C语言用( C )表示逻辑“真”值。 A)true B)t或y C)非零整数值D)整数0 10﹑指出下面正确的输入语句( B )。 A) scanf("a=b=%d",&a,&b) ; B) scanf("%d,%d",&a,&b) ; C) scanf("%c",c) ; D) scanf("% f%d\n",&f) ; 11﹑若x=5,y=3 则y*=x+5; y的值为(D )。 A)10 B)20 C)15 D)30 · 12﹑设整型变量n的值为2,执行语句"n+=n-=n*n;"后,n的值是( C )。 A)0 B)4 C)- 4 D)2 13﹑以下程序的运行结果是( D )。 void main() { int a=65; char c=’A’;

相关主题