收藏 分享(赏)

大学计算机二级考试试题及其答案 !!!.doc

上传人:weiwoduzun 文档编号:4165907 上传时间:2018-12-12 格式:DOC 页数:22 大小:76.50KB
下载 相关 举报
大学计算机二级考试试题及其答案 !!!.doc_第1页
第1页 / 共22页
大学计算机二级考试试题及其答案 !!!.doc_第2页
第2页 / 共22页
大学计算机二级考试试题及其答案 !!!.doc_第3页
第3页 / 共22页
大学计算机二级考试试题及其答案 !!!.doc_第4页
第4页 / 共22页
大学计算机二级考试试题及其答案 !!!.doc_第5页
第5页 / 共22页
点击查看更多>>
资源描述

1、全国计算机二级考试试题【1.1】以下不正确的 C 语言标识符是 _。 A) int B) a_1_2 C) ab1exe D) _x 【1.2】以下是正确的 C 语言标识符是 _。 A) #define B) _123 C) %d D) n【1.3】下列四组字符串中都可以用作语言程序标识符的一组是 。 A) print B) iam C) Pxq D) str_l _3d one_half My-book Cpp oodbs tart$it line# pow aBc 3pai His.age while 【1.4】下面各选项组中,均是 C 语言关键字的组是 。 A) auto, enum,i

2、nclude B) switch,typedef,continue C) signed,union,scanf D) if,struct,type 【1.5】下列不属于 C 语言关键字的是 。 A) default B) register C) enum D) external 【1.6】C 语言程序从 main()函数开始执行,所以这个函数要写在_。 A) 程序文件的开始 B) 程序文件的最后 C) 它所调用的函数的前面 D) 程序文件的任何位置 【1.7】下列关于 C 语言的叙述错误的是 _ A) 大写字母和小写字母的意义相同 B) 不同类型的变量可以在一个表达式中 C) 在赋值表达式中等

3、号(=)左边的变量和右边的值可以是不同类型 D) 同一个运算符号在不同的场合可以有不同的含义 【1.8】在 C 语言中,错误的 int 类型的常数是 。 A) 32768 B) 0 C) 037 D) 0xAF 【1.9】执行语句 printf(“%x“,-1);屏幕显示_。 A) -1 B) 1 C) -ffff D) ffff 【1.10】已知 long i=32768;执行语句 printf(“%d“,i);屏幕显示_。 A) -1 B) -32768 C) 1 D) 32768 【1.11】已知 long i=65539;执行语句 printf(“%d“,i);屏幕显示_。 A) 65

4、539 B) -3 C) 3 D) 程序不能执行 【1.12】在语言中,整数-8 在内存中的存储形式是 。 A) 1111 1111 1111 1000 B) 1000 0000 0000 1000 C) 0000 0000 0000 1000 D) 1111 1111 1111 0111 【1.13】C 语言中字符型(char)数据在内存中的存储形式是_。 A) 原码 B) 补码 C) 反码 D) ASCII 码 【1.14】将字符 g 赋给字符变量 c,正确的表达式是 。 A) c=147 B) c=“147“ C) c=147 D) c=0147 【1.15】下列转义字符中错误的一个是_

5、。 A) 000 B) 0014 C) x111 D) 2 【1.16】将空格符赋给字符变量 c,正确的赋值语句是_。 A) c=0 B) c=NULL C) c=0 D) c=32 【1.17】已知:char a=70 ;则变量 a 中 。 A) 包含 1 个字符 B) 包含 2 个字符 C) 包含 3 个字符 D) 说明非法 【1.18】字符串“EOFn=-61“的长度是_。 A) 8 B) 9 C) 14 D) 非法字符串 【1.19】字符串“的长度是_ 。 A) 0 B) 1 C) 2 D) 非法字符串 【1.20】已知:char a ;int b;float c;double d;执

6、行语句 “c=a+b+c+d;“后,变量 c 的数据类型是 。 A) int B) char C) float D) double 【1.21】温度华氏和摄氏的关系是: C=-(F-32)。已知:float C,F ;由华氏求摄氏的正确的赋值表达式是_。 A) C=5/9(F-32) B) C=5*(F-32)/9 C) C=5/9*(F-32) D) 三个表达式都正确 【1.22】逗号表达式“(a=3*5,a*4),a+15“的值是_。 A) 15 B) 60 C) 30 D) 不确定 【1.23】如果 int a=1,b=2,c=3,d=4;则条件表达式“a5&+x=57&c=90&c=1

7、22 B) !(c=57&c=90&c=122) C) c=48&c=65&c=97&c=48&c=65&c=97&c0)&(xy); A) 1 B) 2 C) 3 D) 程序运行有错误 【1.49】已知 char a20=“Beijing“,“shanghai“,“tianjin“,“chongqing“ ; 语句 printf(“%c“,a30);的输出是 _。 A) B) n C) 不定 D) 数组定义有误 【1.50】若用数组名作为函数调用时的实参,则实际上传递给形参的是 。 A) 数组首地址 B) 数组的第一个元素值 C) 数组中全部元素的值 D) 数组元素的个数 【1.51】对二维

8、数组的正确说明是_。 A) int a=1,2,3,4,5,6; B) int a2=1,2,3,4,5,6; C) int a3=1,2,3,4,5,6; D) int a2,3=1,2,3,4,5,6; 【1.52】对字符数组 s 赋值,不合法的一个是_。 A) char s=“Beijing“; B) char s20=“beijing“; C) char s20; s=“Beijing“; D) char s20=B,e,i,j,i,n,g; 【1.53】对字符数组 str 赋初值,str 不能作为字符串使用的一个是_。 A) char str=“shanghai“; B) char

9、str=“shanghai“; C) char str9=s,h,a,n,g,h,a,i; D) char str8= s,h,a,n,g,h,a,i; 【1.54】对函数形参的说明有错误的是_。 A) int a(float x,int n) B) int a(float *x,int n) C) int a(float x10,int n) D) int a(float x,int n) 【1.55】如果一个变量在整个程序运行期间都存在,但是仅在说明它的函数内是可见的,这个变量的存储类型应该被说明为_。 A) 静态变量 B) 动态变量 C) 外部变量 D) 内部变量 【1.56】在一个 C

10、 源程序文件中 ,若要定义一个只允许在该源文件中所有函数使用的变量,则该变量需要使用的存储类别是 。 A) extern B) register C) auto D) static 【1.57】在 C 语言中,函数的数据类型是指 _。 A) 函数返回值的数据类型 B) 函数形参的数据类型 C) 调用该函数时的实参的数据类型 D) 任意指定的数据类型 【1.58】已知如下定义的函数: fun1(a) printf(“n%d“,a); 则该函数的数据类型是_。 A) 与参数 a 的类型相同 B) void 型 C) 没有返回值 D) 无法确定 【1.59】定义一个函数实现交换 x 和 y 的值,并

11、将结果正确返回。能够实现此功能的是_。 A) swapa(int x,int y) B) swapb(int *x,int *y) int temp; int temp; temp=x;x=y; y=temp; temp=x;x=y;y=temp; C) swapc(int *x,int *y) D) swapd(int *x,int *y) int temp; int *temp; temp=*x;*x=*y ;*y=temp; temp=x;x=y;y=temp; 【1.60】求一个角的正弦函数值的平方。能够实现此功能的函数是_。 A) sqofsina(x) float x; retur

12、n(sin(x)*sin(x); B) double sqofsinb(x) float x; return(sin(double)x)*sin(double)x); C) double sqofsinc(x) return(sin(x)*sin(x); D) sqofsind(x) float x; return(double(sin(x)*sin(x)【1.61】一个函数内有数据类型说明语句如下: double x,y,z(10); 关于此语句的解释,下面说法正确的是_。 A) z 是一个数组,它有 10 个元素。 B) z 是一个函数,小括号内的 10 是它的实参的值。 C) z 是一个

13、变量,小括号内的 10 是它的初值。 D) 语句中有错误。 【1.62】已知函数定义如下: float fun1(int x,int y) float z; z=(float)x/y; return(z); 主调函数中有 int a=1,b=0;可以正确调用此函数的语句是_。 A) printf(“%f“,fun1(a,b); B) printf(“%f“,fun1(&a,&b); C) printf(“%f“,fun1(*a,*b); D) 调用时发生错误 【1.63】下面函数的功能是_。 a(s1,s2) char s1,s2; while(s2+=s1+) ; A) 字符串比较 B) 字

14、符串复制 C) 字符串连接 D) 字符串反向 【1.64】在下列结论中,只有一个是错误的,它是 。 A) C 语言允许函数的递归调用 B) C 语言中的 continue 语句,可以通过改变程序的结构而省略 C) 有些递归程序是不能用非递归算法实现的 D) C 语言中不允许在函数中再定义函数 【1.65】已知:int a, *y=&a ;则下列函数调用中错误的是 。 A) scanf(“%d“, &a); B) scanf(“%d“, y); C) printf(“%d“, a); D) printf(“%d“, y); 【1.66】说明语句“int (*p)( );“的含义是 。 A) p

15、是一个指向一维数组的指针变量 B) p 是指针变量,指向一个整型数据 C) p 是一个指向函数的指针,该函数的返回值是一个整型 D) 以上都不对 【1.67】设有说明 int (*p)4;其中的标识符 p 是 。 A) 4 个指向整型变量的指针变量 B) 指向 4 个整型变量的函数指针 C) 一个指向具有 4 个整型元素的一维数组的指针 D) 具有 4 个指向整型变量的指针元素的一维指针数组 【1.68】已知:char s10, *p=s,则在下列语句中,错误的语句是 。 A) p=s+5; B) s=p+s; C) s2=p4; D) *p=s0; 【1.69】已知:char s100;in

16、t i;则引用数组元素的错误的形式是 。 A) si+10 B) *(s+i) C) *(i+s) D) *(s+)+i) 【1.70】已知:char s6, *ps=s;则正确的赋值语句是 。 A) s=“12345“; B) *s=“12345“; C) ps=“12345“; D) *ps=“12345“; 【1.71】已知:char a310=“BeiJing“,“ShangHai“,“TianJin“, *pa=a;不能正确显示字符串“ShangHai“的语句是 。 A) printf(“%s“,a+1); B) printf(“%s“,*(a+1); C) printf(“%s“,

17、*a+1); D) printf(“%s“,&a10); 【1.72】已知:int a43=1,2,3,4,5,6,7,8,9,10,11,12; int (*ptr)3=a,*p=a0; 则以下能够正确表示数组元素 a12的表达式是 。 A) *(*(a+1)+2) B) *(*(p+5) C) (*ptr+1)+2 D) *(ptr+1)2) 【1.73】已知:int a =1,2,3,4,5,6,7,8,9,10,11,12,*p=a;则值为 3 的表达式是 。 A) p+=2,*(p+) B) p+=2,*+p C) p+=2,*p+ D) p+=2,+*p 【1.74】已知:int

18、a=1,2,3,4, y, *p=a;则执行语句 y = (*+p)-;之后, 数组 a 各元素的值变为_。 A) 0,1,3,4 B) 1,1,3,4 C) 1,2,2,4 D) 1,2,3,3 变量 y 的值是_。 A) 1 B) 2 C) 3 D) 4 【1.75】已知:int a =1,3,5,7, y *p= a;为使变量 y 的值为 3,下列语句正确的是_。 A) y=+*p+; B) y=+(*p+); C) y=(+*p)+; D) y=(*+p)+; 【1.76】已知:int x = 1,3,5,7,9,11 ,*ptr=x;则能够正确引用数组元素的语句是 。 A) x B)

19、 *(ptr-) C) x6 D) *(-ptr) 【1.77】函数的功能是交换变量 x 和 y 中的值,且通过正确调用返回交换的结果。能正确执行此功能的函数是 。 A) funa (int *x, int *y) B) funb (int x, int y) int *p; int t; p=x;*x=*y;*y=*p ; t=x ; x=y;y=t; C) func (int *x, int *y) D) func (int *x, int *y) *x=*y;*y=*x; *x=*x+*y;*y=*x-*y;*x=*x-*y; 【1.78】有定义如下: struct sk int a;

20、float b; data ,*p; 如果 p=&data;则对于结构变量 data 的成员 a 的正确引用是_。 A)(*) .data.a B) (*p).a C) p-data.a D) p.data.a 【1.79】已知: struct st int n; struct st *next; ; static struct st a3=1,&a1,3,&a2,5,&a0,*p; 如果下述语句的显示是 2,则对 p 的赋值是_。 printf(“%d“,+(p-next-n); A) p=&a0; B) p=&a1; C) p=&a2; D) p=&a3; 【1.80】已知: struct

21、 person char name10; int age; class10=“LiMing“,29,“ZhangHong“,21,“WangFang“,22; 下述表达式中,值为 72 的一个是_。 A) class0-age + class1-age+ class2-age B) class1.name5 C) person1.name5 D) clase-name5 【1.81】已知: struct int i; char c; float a; test; 则 sizeof(test)的值是 。 A) 4 B) 5 C) 6 D) 7 【1.82】已知: union int i; cha

22、r c; float a; test; 则 sizeof(test)的值是 。 A) 4 B) 5 C) 6 D) 7 【1.83】已知: union u_type int i; char ch; float a; temp; 现在执行“temp.i=266 ;printf(“%d“,temp.ch)“的结果是 。 A) 266 B) 256 C) 10 D) 1 【1.84】若有以下程序段: struct dent int n; int *m; ; int a=1,b=2,c=3; struct dent s3 = 101,&a,102,&b,103,&c ; struct dent *p=

23、s; 则以下表达式中值为 2 的是 。 A) (p+)-m B) *(p+)-m C) (*p).m D) *(+p)-m 【1.85】若有以下说明语句,则对结构变量 pup 中 sex 域的正确引用是 。 struct pupil char name20; int sex; pup,*p; p=&pup; A) p.pup.sex B) p-pup.sex C) (*p).pup.sex D) (*p).sex 【1.86】以下对结构变量 stul 中成员 age 的非法引用是 。 struct student int age; int num; stu1,*p; p=&stu1; A) s

24、tu1.age B) student.age C) p-age D) (*p).age 【1.87】若有以下定义和语句: union data int i; char c; float f; a; int n; 则以下语句正确的是_。A) a=5; B) a=2,a,1.2; C) printf(“%dn“,a); D) n=a; 【1.88】已知: struct sk int a; int age; date,*p; 如果要使指针 p 指向 data 中的成员 a,正确的赋值语句是_。 A) p = (struct sk *)&data.a; B) p = (struct sk *)data

25、.a; C) p = &data.a; D) *p = data.a;答案【1.1】答案: A注释:int 是 C 语言的关键字【1.2】答案: B【1.3】答案:A【1.4】答案:B注释:include 是预处理命令;scanf 是函数名;type 不是 C 语言的关键字。【1.5】答案:D【1.6】答案:D【1.7】答案:A【1.8】答案:A注释:int 型表示整数的范围是-3276832767。【1.9】答案:D注释:整型常量-1 在计算机中表示为补码 1111 1111 1111 1111,用十六进制显示这个数时,最左边的 1 不会被解释为符号位,而是与右边其它位共同转换为十六进制数。

26、【1.10】答案:B注释:长整型数 32768 在计算机内的表示是 1000 0000 0000 0000,以一般整型进行输出时,此数恰是-32768 的补码。【1.11】答案:C注释:长整型数 65539 在计算机内的表示是 0001 0000 0000 0000 0011,以一般整型进行输出时,仅将右侧 16 位二进制数转换为十进制数。【1.12】答案:A注释:C 语言中,int 型的负数是采用补码表示的。【1.13】答案:D【1.14】答案:C注释:变量 c 是字符型,可用字符常量为它赋值。字符常量必须用单引号括起来,所以 B是错误的;在单引号或双引号内的反斜线用于表示转义字符,A 选项

27、在无引号时使用反斜线是错误的;C 选项单引号内出现反斜线表示它与后面的数字组成一个转义字符;单引号只允许括起一个字符,D 选项在单引号内出现 4 个字符,是错误的。【1.15】答案:C【1.16】答案:D注释:空字符和空格符是不同的两个字符,空格符的 ASCII 码值是 32,空字符的 ASCII 值是 0。【1.17】答案:A【1.18】答案:B【1.19】答案:A【1.20】答案:C【1.21】答案:B注释:单纯从 C 语言语法来说,选项 B、C 都是正确的,但是选项 C 中第一个运算的两个对象都是整型常数,其结果也是整型数 0,最后的运算结果也就是 0 了。【1.22】答案:C【1.23

28、】答案:A注释:将条件表达式增加一个括号,此式变为 a。next 是 a0的地址,引用其成员 n 再做前增 1 运算,结果就是 2。【1.80】答案:B【1.81】答案:D【1.82】答案:A【1.83】答案:C注释:联合变量 temp 的成员是占用同一存储单元,它的长度是 4 个字节。266 的二进制表示是 100001010,存放在存储单元的低端两个字节,如下图:高字节 0 0 0 0 0 0 0 1低字节 0 0 0 0 1 0 1 0引用 temp.ch 进行输出,只取最低的第一个字节。【1.84】答案:D注释:由于结构指针指向了结构数组的 0 号元素,所以表达式(p+)-m 的含义是先取出m(变量 a 的地址),然后指针 p 加 1。表达式*(p+)-m 的含义是先取出 m 的内容(变量a 的值),然后指针 p 再加 1。表达式(*p).m 的含义是取出 m(变量 a 的地址)。表达式*(+p)-m 的含义是先将指针 p 加 1,然后再取 m 的内容(变量 b 的值)。【1.85】答案:D【1.86】答案:B【1.87】答案:C【1.88】答案:A

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 教育教学 > 计算机等级考试

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报