1、”的长度是A 8B 9C 12D 非法字符串9.数学式 sin x在 C 程序中对应的不正确的表达式为Asqrt(sin(x)0?sin(x):-sin(x) Bsqrt(fabs(sinx)Csqrt(sqrt(sinx*sinx) Dfabs(sqrt(sin(x)10. 下列A _No1是 C 语言的有效标识符 ?BNo.1 C12345Dint11.C 语言中,表示一条语句结束的标号是A# B; C/ D12.每个 C 程序中都必须有且仅有一个A 类B预处理命令C主函数D语句13.下列数据类型不是 C 语言基本数据类型的是A 字符型B整型C实型D数组14.下列字符列中,可作为 C 语言
2、程序自定义标识符是AswitchB fileC breakD do15.运算符 +、=、=、% 中,优先级最低的运算符是A +Bb?a大于 b:a小于b;%sn, s1);A. a 大于 bB. a 小于bC. 1D. 输出语句有错24. int k=10;while(k=0) k=k-1;则下面描述正确的是A. while 循环执行 10 次C. 循环体语句一次也不执行B. 循环是无限循环D. 循环体语句执行一次25.int a=1,b=2,c=2,t; while(ab) t=a;a=b;b=t;c-; printf(%d,%d,%dn,a,b,c);运行结果为 。A. 1,2,0 B.
3、2,1,0 C. 1,2,1 D. 2,1,126.int x=-1; do x=x*x; while(!x);下列说法正确的是A. 是死循环B. 循环执行两次C. 循环执行一次D. 有语法错误27. 以下能正确计算1*2*3*10 的程序段是A. do i=1;s=1;B. do i=1;s=0;s=s*i; i+;i+;while(i=10);C. i=1;D. i=1;do s=s*i;dos=s*i;28. 以下描述正确的是A. 由于 do-while 循环中循环体语句只是一条可执行语句, 所以循环体内不能使用复合语句B. do-while 循环由 do 开始,用 while 结束,在
4、 while(表达式 )后面不能写分号 C. 在 do-while 循环体中,一定要有能使 while 后面表达式的值变为零 (“假”)的操作D. do-while 循环中,根据情况可以省略while29.while 和 do-while 循环的主要区别是A. do-while 的循环体至少无条件执行一次B. while 的循环控制条件比 do-while 的循环控制条件严格C. do-while 允许从外部转到循环体内D. do-while 的循环体不能是复合语句30.下面有关 for 循环的正确描述是A. for 循环只能用于循环次数已经确定的情况B. for 循环是先执行循环体语句,后判
5、断表达式C. for 循环中,不能用 break 语句跳出循环体D. for 循环的循环体语句中,可以包含多条语句,但必须用花括号括起来31.对 for(表达式 1; ;表达式 3)可理解为A. for( 表达式 1;0;表达式 3)B. for( 表达式 1; 1;C. for(表达式 1;表达式 1;D. or(表达式 1;表达式 3;32.在 C 编程语言中,以下正确的描述是A.continue 语句的作用是结束整个循环的执行B.只能在循环体内和 switch 语句体内使用 break 语句C.在循坏体内使用 break 语句或 continue 语句的作用相同D.从多层循环嵌套中退出,
6、只能使用 goto 语句33.下面程序段。 for(t=1;t=100;t+) scanf(%d,&if(x0) continue; printf(%dn,t);A. 当 x=0 时什么也不输出D. 最多允许输出 100 个非负整数34.定义一个函数实现交换 x 和 y 的值,并将结果正确返回。能够实现此功能的是 。A. swap(int x, int y) int t; t=x; x=y; y=t; B. swap(int *x, int *y) int t;C. swap(int *x, int *y) int t; t= *x; *x = *y; *y=t;D. swap(int *x,
7、 int *y) int *t;35.若有代数式 3ae/bc,则不正确的 C 语言表达式是A. a/b/c*e*3B. 3*a*e/b/cC. 3*a*e/b*cD. a*e/c/b*336.以下表达式值为 3 的是A. 16-13%10 B. 2+3/2C. 14/3-2D. (2+6)/(12-9)37.设有说明语句, int k=7, x=12 ;则以下能使值为3 的表达式是。A. x%=(k%=5)B. x%=(k-k%5)C. x%= k-k%5D. (x%=k)-(k%=5)38.若有条件表达式 (exp)? A+: b-,则以下表达式中能完全等价于表达式 (exp)的是A. (
8、exp= =0)B. (exp!=0)C. (exp= =1)D. (exp!=1)39. 设有以下语句:typedef struct REC char c; int a4; REC1;则下面叙述中正确的是A可以用 REC 定义结构体变量BREC1 是 struct REC 类型的变量C REC 是 struct 类型的变量D可以用 REC1 定义结构体变量40. 下列关于结构的语法错误的是A结构是由用户自定义的一种数据类型B结构中可设定若干个不同数据类型的成员C结构中成员的数据类型可以是另一个已定义的结构D在定义结构时,可以为成员设置默认值41. 以下关于结构体的叙述中,错误的是A结构体是一
9、种可由用户构造的数据类型B结构体中的成员可以具有不同的数据类型C结构体中的成员不可以与结构体变量同名D结构体中的成员可以是指向自身结构的指针类型42. 说明一个结构体变量时,系统分配给它的内存是A各成员所需内存量的总和B结构中第一个成员所需内存量C成员中占内存量最大者所需的容量D结构中最后一个成员所需内存量43.设有以下说明语句:struct stu int a; float b; stutype;则下面的叙述不正确的是 。A struct 是结构体类型的关键字Bstruct stu 是用户定义的结构体类型名C stutype 是用户定义的结构体类型名D a 和 b 都是结构体成员名44.若有
10、如下定义struct data int x,y;test1=10,20, test2;则以下赋值语句中错误的是A. test2=test1; B. test2.x=test1.x;C. test2.x=test1.y D. test2=30,40;45. 以下对结构体变量 stu1 中成员 age的非法引用是struct student int age; int num; stu1,*p;p=&stu1;A. stu1.age B. student.age C. p-age D. (*p).age46. 当说明一个共用体变量时,系统分配给它的内存是A.各成员所需内存量的总合47. 以下对 C
11、语言中共用体类型数据的叙述正确的是 。A可以对共用体变量名直接赋值B一个共用体变量中可以同时存放其所有成员C一个共用体变量中不能同时存放其所有成员D共用体类型定义中不能出现结构体类型的成员48.若有以下定义和语句:union data int i; char c; float f; a; int n;则以下语句正确的是A a=5;B. a=2, a,1.2C. printf( “%dn”,a);D. n=1;49. 设有以下说明,则下面不正确的叙述是union un;A. un 所占的内存长度等于成员 f 的长度Bun 的地址和它的成员地址都是同一地址C un 可以作为函数参数D不能对 un
12、赋值,但可以在定义 un 时对它初始化50.C 语言共用体类型变量在程序运行期间A所有成员一直驻留在内存中B只有一个成员驻留在内存中C部分成员驻留在内存中D没有成员驻留在内存中51. 使用typedef 定义一个新类型的正确步骤是A(2)、(4)、(1)、(3) B. (1)、(3)、(2)、(4)C(2)、(1)、(4)、(3) D. (4)、(2)、(3)、(1)(1) 把变量名换成新类型名(2) 按定义变量的方法写出定义体(3) 用新类型名定义变量(4) 在最前面加上关键则 typedef52. 下面对 typedef 的叙述中不正确的是 。A用 typedef 可以定义各种类型名,但不
13、能用来定义变量B用 typedef 可以增加新类型C用 typedef 只是将已存在的类型用一个新的标识符来代表D使用 typedef 有利于程序的通用和移植53. 下面试图为 double 说明一个新类型名 real 的语句中,正确定是A typedef real double;B. typedef double real;C. typedef real=double;D. typedef double=real;54. 下面能正确进行字符串赋值操作的是A. char s5= “ABCDE ”;B. char s5= A,B,C,D,E;C. char *s; s=“ABCDE ”;D. c
14、har *s; scanf(“%s”,s);55. 下面程序段的运行结果是char *s=”abcde”;s+=2;printf( “%d”,s);A. cdeB. 字符 cC. 字符 c 的地址D. 无确定的输出结果56. 下面程序段的运行结果是char str =”ABC ”, *p=str;printf( “%dn”, *(p+3);A. 67 B. 0 C. 字符 C 的地址 D.字符57. 下面程序段的运行结果是 。char a =”language”, *p;p=a;while(*p!= u)printf( “%c”,*p-32); p+;A. LANGUAGE B. langua
15、ge C. LANG58. 有如下说明语句,则以下不正确的叙述是char a =”It is mine”;char *p=”It is mine”;A. a+1 表示的是字符 t 所在存储单元的地址CD. langUAGEBp 指向另外的字符串时,字符串的长度不受限制C p 变量中存放的地址值可以改变D a 中只能存放 10 个字符答案:1A 2C 3C 4D 5C 6B 7D8A9B 10A11B 12 C 13D 14 B 15C 16 B17A 18D19A 20C21D 22B23 A24C25D 26C27C 28C 29A 30D 31B32B33D 34C35C36B37. D3
16、8. B39. D40. D41. C42. A43. C44. D 45. B 46.C47.C48.B49.C50.B51.C52. B53. B54.C55.C56. B57. C58. D二、填空题程序的三种基本的控制结构是:、C 语言中的每条基本语句以作为结束符,每条复合语句以作为结束符。3.关系表达式 x+y5 的相反表达式为4.下面的程序段中循环体的执行次数是a=10;b=0;dob+=2;a-=2+b; while(a=0);5.下面程序段的运行结果为x=2;doprintf(* x-; while(!x=0);6.已知 int a32=3, 2, 1;则表达式“ a00/a0
17、1 ”的值是7.若用数组名作为函数调用时的实参,则实际上传递给形参的是如果一个函数无返回值,定义它时函数类型应是预处理命令以开头。10.指针类型变量用于存储,在内存中它占有一个存储空间。11.赋值语句在执行时先计算,再将该值转换成与一致的值,并将值赋给左部变量。12.在程序中 else 总是与的 if 配对,而不管程序的书写格式如何。在函数中使用语句返回值。函数的形参在未被调用前分配空间,函数形参的要和实参相同。函数调用一般分,前者的特点是形参和实参各有独立的存储空间, 形参的存储空间在函数被调用时才分配, 形参内容的变化不影响实参,后者的特点是形参实参共用一个存储空间, 形参内容的改变可以改
18、变实参值。在传值调用中,实际是把实参的传给形参。int a3=3; 则 a2=int a3=1, 3, 5, 7;则19.数组由和构成,其数组元素的数据类型是20.声明长度为 10的 float型 数 组a , 且 初 始 化 为0 的语句是:21.指针是存放一个变量的22.当数组名作形参时,相当于23.要访问数组元素可以采用24.定义一个指针 p,它指向一个有的变量。、 、 。6个整型元素的一维数组,定义语句为 。25.定义一个指针数组 p,它有 4 个元素,每个指针指向一个整型数据,定义语句为 。26.指针可以指向字符串,在定义一个字符型指针时,可以给它初始化,目的是把字符串的 放入指针变
19、量。27.指针可以指向函数,这时它所指的是函数的28.C 语言的源程序必须通过后,才能被计算机执行。C 语言源程序文件的后缀是;经过编译后,生成文件的后缀经过连接后,生成文件的后缀是在 C 语言中,表示逻辑“真”值用设 y 为 int 型变量,请写出描述“ y 是奇数”的表达式C 语言提供的 3 种逻辑运算符是33.若 x、 y、z 均为 int 型变量,则描述“ x 或 y 中有一个小于 z”的表达式34.设 a、b、c 均为 int 型变量且 a=7.5, b=2,c=3.6,则表达式 a c| ab 的值是设 a、b、c 均为 int 型变量且 a=6, b=4,c=2, 则表达式 !(a-b)+c-1 b+c/2的值是设 a、b 均为 int 型变量且 a=2, b=4, 则表达式 !(x=a) | (y=b)0 的值设 a、b、c 均为 int 型变量且 a=1, b=4,c=3, 则表达式 !(ab)| !c & 1 的值是38.若有条件“ 2x3 或 x-10”,其对应的 C 语言表达式是
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1