全国计算机等级考试(二级)考试试题

全国计算机等级考试(二级)考试试题

ID:44745361

大小:76.51 KB

页数:22页

时间:2019-10-27

上传者:简单2019
全国计算机等级考试(二级)考试试题_第1页
全国计算机等级考试(二级)考试试题_第2页
全国计算机等级考试(二级)考试试题_第3页
全国计算机等级考试(二级)考试试题_第4页
全国计算机等级考试(二级)考试试题_第5页
资源描述:

《全国计算机等级考试(二级)考试试题》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

全国计算机二级考试试题【1.1】以下不正确的C语言标识符是____。A) int B) a_1_2 C) ab1exe D) _x【1.2】以下是正确的C语言标识符是____。A) #define B) _123 C) %d D)  【1.3】下列四组字符串中都可以用作C语言程序标识符的一组是 。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,include B) switch,typedef,continueC) 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) 在赋值表达式中等号(=)左边的变量和右边的值可以是不同类型 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) 65539 B) -3 C) 3 D) 程序不能执行【1.12】在C语言中,整数-8在内存中的存储形式是 。A) 1111 1111 1111 1000 B) 1000 0000 0000 1000C) 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】下列转义字符中错误的一个是____。A) ’00’ B) ’014’ C) ’x111’ D) ’2’【1.16】将空格符赋给字符变量c,正确的赋值语句是____。A) c=’’ B) c=NULL C) c=0 D) c=32【1.17】已知:char a=’70’;则变量a中 。A) 包含1个字符 B) 包含2个字符 C) 包含3个字符 D) 说明非法【1.18】字符串""EOF =-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;执行语句"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<10;A) 1 B) 2 C) 3 D) 4【1.27】为判断字符变量c的值不是数字也不是字母时,应采用下述表达式____。A) c<=48||c>=57&&c<=65||c>=90&&c<=97||c>=122B) !(c<=48||c>=57&&c<=65||c>=90&&c<=97||c>=122)C) c>=48&&c<=57||c>=65&&c<=90||c>=97&&c<=122D) !(c>=48&&c<=57||c>=65&&c<=90||c>=97&&c<=122)【1.28】已知 int a[3][2]={3,2,1};则表达式"a[0][0]/a[0][1]/a[0][2]"的值是____。A) 0.166667 B) 1 C) 0 D) 错误的表达式【1.29】已知 int x=1,y=1,z=1;表达式"x+++y+++z++"的值是____。A) 3 B) 4 C) 5 D) 表达式错误【1.30】用十进制表示表达式"12|012"的值是____。A) 1 B) 0 C) 12 D) 14【1.31】已知以下程序段:int a=3,b=4;a=a^b;0011        0100         0111b=b^a;0100        0011        0111         0100a=a^b;则执行以上语句后a和b的值分别是____。A) a=3,b=4B) a=4,b=3 C) a=4,b=4 D) a=3,b=3【1.32】在位运算中,操作数每右移一位,其结果相当于____。A) 操作数乘以2 B) 操作数除以2 C) 操作数除以16 D) 操作数乘以16【1.33】已知 char a=222;执行语句a=a&052;后,变量a的值是____。A) 222 B) 10 C) 244 D) 254【1.34】已知二进制数a是00101101,如果想通过整型变量b与a做异或运算,使变量a的高4位取反,低4位不变,则二进制数b的值应是____。A) 11110000 B) 00001111 C) 11111111 D) 00000000【1.35】已知 int a=15,执行语句a=a<<2以后,变量a的值是____。A) 20 B) 40 C) 60 D) 80【1.36】已知int x=5,y=5,z=5;执行语句x%=y+z;后,x的值是____。A) 0 B) 1 C) 5 D) 6 【1.37】使用语句scanf("x=%f,y=%f",&x,&y);输入变量x、y的值(□代表空格),正确的输入是____。A) 1.25,2.4 B) 1.25□2.4 C) x=1.25,y=2.4 D) x=1.25□y=2.4【1.38】下列循环语句中有语法错误的是____。A) while(x=y) 5; B) while(0) ;C) do 2;while(x==b); D) do x++ while(x==10);【1.39】已知int x=(1,2,3,4);变量x的值是____。A) 1 B) 2 C) 3 D) 4【1.40】表达式sizeof(double)是 。A) 函数调用 B) double型表达式 C) int型表达式 D) 非法表达式【1.41】执行语句printf("2:%d,",printf("1:%d,",scanf("%d",&x)));以后的输出结果是____。A) 2:1,1:1, B) 1:1,2:1, C) 2:4,1:1 D) 1:1,2:4,【1.42】已知:int x,y;double z;则以下语句中错误的函数调用是 。A) scanf ("%d,%lx,%le",&x,&y,&z);B) scanf ("-*%d%lf",&x,&y,&z);C) scanf ("%x%*d%o",&x,&y); D) scanf ("%x%o%6.2f",&x,&y,&z);【1.43】与条件表达式"(n)?(c++):(c--)"中的表达式(n)等价的表达式是____。 A) (n==0) B) (n==1) C) (n!=0) D) (n!=1)【1.44】已知int i=1,j=0;执行下面语句后j的值是____。while(i)switch(i){ case 1: i+=1;j++;break;case 2: i+=2;j++;break;case j3: i+=3;++;break;default: i--;j++;break;}A) 1 B) 2 C) 3 D) 死循环【1.45】求取满足式 12+22+32+ …… +n2 ≤1000的n,正确的语句是____。A) for(i=1,s=0;(s=s+i*i)<=1000;n=i++) ; B) for(i=1,s=0;(s=s+i*i)<=1000;n=++i) ;C) for(i=1,s=0;(s=s+i*++i)<=1000;n=i) ; D) for(i=1,s=0;(s=s+i*i++)<=1000;n=i) ;【1.46】下面的for语句 。for(x=0,y=10;(y>0)&&(x<4);x++,y-- ) ;A) 是无限循环 B) 循环次数不定 C) 循环执行4次 D) 循环执行3次【1.47】已知int i=1; 执行语句while (i++<4) ;后,变量i的值为____。A) 3 B) 4 C) 5 D) 6【1.48】已知int x=12,y=3;执行下述程序后,变量x的值是____。do{ x/=y--;}while(x>y); A) 1 B) 2 C) 3 D) 程序运行有错误【1.49】已知 char a[][20]={"Beijing","shanghai","tianjin","chongqing"};语句printf("%c",a[30]);的输出是____。A) <空格> B) n C) 不定 D) 数组定义有误【1.50】若用数组名作为函数调用时的实参,则实际上传递给形参的是 。A) 数组首地址 B) 数组的第一个元素值C) 数组中全部元素的值 D) 数组元素的个数【1.51】对二维数组的正确说明是____。A) int a[][]={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};【1.52】对字符数组s赋值,不合法的一个是____。A) char s[]="Beijing"; B) char s[20]={"beijing"};C) char s[20];s="Beijing"; D) char s[20]={’B’,’e’,’i’,’j’,’i’,’n’,’g’};【1.53】对字符数组str赋初值,str不能作为字符串使用的一个是____。A) char str[]="shanghai";B) char str[]={"shanghai"}; C) char str[9]={’s’,’h’,’a’,’n’,’g’,’h’,’a’,’i’};D) char str[8]={ ’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 x[10],int n) D) int a(float x,int n)【1.55】如果一个变量在整个程序运行期间都存在,但是仅在说明它的函数内是可见的,这个变量的存储类型应该被说明为____。A) 静态变量 B) 动态变量 C) 外部变量 D) 内部变量【1.56】在一个C源程序文件中,若要定义一个只允许在该源文件中所有函数使用的变量,则该变量需要使用的存储类别是 。A) extern B) register C) auto D) static【1.57】在C语言中,函数的数据类型是指____。A) 函数返回值的数据类型 B) 函数形参的数据类型C) 调用该函数时的实参的数据类型 D) 任意指定的数据类型【1.58】已知如下定义的函数:fun1(a){ printf(" %d",a);}则该函数的数据类型是____。A) 与参数a的类型相同 B) void型C) 没有返回值 D) 无法确定【1.59】定义一个函数实现交换x和y的值,并将结果正确返回。能够实现此功能的是____。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;{ return(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是一个变量,小括号内的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) 字符串复制 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是一个指向一维数组的指针变量B) p是指针变量,指向一个整型数据C) p是一个指向函数的指针,该函数的返回值是一个整型D) 以上都不对【1.67】设有说明int (*p)[4];其中的标识符p是 。A) 4个指向整型变量的指针变量B) 指向4个整型变量的函数指针C) 一个指向具有4个整型元素的一维数组的指针D) 具有4个指向整型变量的指针元素的一维指针数组【1.68】已知:char s[10], *p=s,则在下列语句中,错误的语句是 。 A) p=s+5; B) s=p+s; C) s[2]=p[4]; D) *p=s[0];【1.69】已知:char s[100];int i;则引用数组元素的错误的形式是 。A) s[i+10] B) *(s+i) C) *(i+s) D) *((s++)+i)【1.70】已知:char s[6], *ps=s;则正确的赋值语句是 。A) s="12345"; B) *s="12345"; C) ps="12345"; D) *ps="12345";【1.71】已知:char a[3][10]={"BeiJing","ShangHai","TianJin"}, *pa=a;不能正确显示字符串"ShangHai"的语句是 。A) printf("%s",a+1); B) printf("%s",*(a+1));C) printf("%s",*a+1); D) printf("%s",&a[1][0]);【1.72】已知:int a[4][3]={1,2,3,4,5,6,7,8,9,10,11,12};int (*ptr)[3]=a,*p=a[0];则以下能够正确表示数组元素a[1][2]的表达式是 。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 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) *(ptr--) C) x[6] 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;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 a[3]={1,&a[1],3,&a[2],5,&a[0]},*p;如果下述语句的显示是2,则对p的赋值是____。printf("%d",++(p->next->n));A) p=&a[0]; B) p=&a[1]; C) p=&a[2]; D) p=&a[3];【1.80】已知:struct person{ char name[10];int age;}class[10]={"LiMing",29,"ZhangHong",21,"WangFang",22};下述表达式中,值为72的一个是____。A) class[0]->age + class[1]->age+ class[2]->ageB) class[1].name[5] C) person[1].name[5]D) clase->name[5]【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;char 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 s[3] = { {101,&a},{102,&b},{103,&c} };struct dent *p=s;则以下表达式中值为2的是 。A) (p++)->m B) *(p++)->m C) (*p).m D) *(++p)->m 【1.85】若有以下说明语句,则对结构变量pup中sex域的正确引用是 。struct pupil{ char name[20];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) stu1.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("%d ",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.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型表示整数的范围是-32768~32767。【1.9】答案:D注释:整型常量-1在计算机中表示为补码1111111111111111,用十六进制显示这个数时,最左边的1不会被解释为符号位,而是与右边其它位共同转换为十六进制数。【1.10】答案:B注释:长整型数32768在计算机内的表示是1000000000000000,以一般整型进行输出时,此数恰是-32768的补码。【1.11】答案:C注释:长整型数65539在计算机内的表示是0001000000000000 0011,以一般整型进行输出时,仅将右侧16位二进制数转换为十进制数。【1.12】答案:A注释:C语言中,int型的负数是采用补码表示的。【1.13】答案:D【1.14】答案:C注释:变量c是字符型,可用字符常量为它赋值。字符常量必须用单引号括起来,所以B是错误的;在单引号或双引号内的反斜线''用于表示转义字符,A选项在无引号时使用反斜线是错误的;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】答案:A注释:将条件表达式增加一个括号,此式变为a。next是a[0]的地址,引用其成员n再做前增1运算,结果就是2。【1.80】答案:B【1.81】答案:D【1.82】答案:A【1.83】答案:C注释:联合变量temp的成员是占用同一存储单元,它的长度是4个字节。266的二进制表示是100001010,存放在存储单元的低端两个字节,如下图:高字节00000001低字节0000101 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

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。
大家都在看
近期热门
关闭