计算机二C语言试题含答案.docx

上传人:b****7 文档编号:25069522 上传时间:2023-06-04 格式:DOCX 页数:19 大小:23KB
下载 相关 举报
计算机二C语言试题含答案.docx_第1页
第1页 / 共19页
计算机二C语言试题含答案.docx_第2页
第2页 / 共19页
计算机二C语言试题含答案.docx_第3页
第3页 / 共19页
计算机二C语言试题含答案.docx_第4页
第4页 / 共19页
计算机二C语言试题含答案.docx_第5页
第5页 / 共19页
点击查看更多>>
下载资源
资源描述

计算机二C语言试题含答案.docx

《计算机二C语言试题含答案.docx》由会员分享,可在线阅读,更多相关《计算机二C语言试题含答案.docx(19页珍藏版)》请在冰豆网上搜索。

计算机二C语言试题含答案.docx

计算机二C语言试题含答案

9月全国计算机等级考试二级笔试试卷

C语言程序设计

<考试时间120分钟,满分100分)

一、选择题((1>-(10>每题2分,(11>-(50>每题1分.共60分>>

下列各题A>、B>、C>、D>四个选项中,只有一个是正确的,请将正确选项涂写在答题卡上,答在试卷上不得分。

<1)软件是指

A)程序                        B)程序和文档

C)算法加数据结构              D)程序、数据和相关文档的集合

<2)软件调试的目的是

A)发现错误                    B)改正错误

C)改善软件的性能              D)验证软件的正确性

<3)在面向对象方法中,实现信息隐蔽是依靠

A)对象的继承                   B)对象的多态

C)对象的封装                   D)对象的分类

<4)下列叙述中,不符合良好程序设计风格的是

A)程序的效率第一,清晰第二     B)程序的可读性好

C)程序中有必要的注释           D)输入数据前要有提示信息

<5)下列叙述中正确的是

A)程序执行的效率与数据的存储结构密切相关

B)程序执行的效率只取决于程序的控制结构

C)程序执行的效率只取决于所处理的数据量

D)以上三种说法都不对

<6)下列叙述中正确的是

A)数据的逻辑结构与存储结构必定是一一对应的

B)由于计算机存储空间是向量式的存储结构,因此,数据的存储结构一定是线性结构

C)程序设计语言中的数组一般是顺序存储结构,因此,利用数组只能处理线线结构

D)以上三种说法都不对

<7)冒泡排序在最坏情况下的比较次数是

A)n

<8)一棵二叉树中共有70个叶子结点与80个度为1的结点,则该二叉树中的总结点数为

A)219           B)221        C)229             D)231

<9)下列叙述中正确的是

A)数据库系统是一个独立的系统,不需要操作系统的支持

B)数据库技术的根本目标是要解决数据的共享问题

C)数据库管理系统就是数据库系统

D)以上三种说法都不对

<10)下列叙述中正确的是

A)为了建立一个关系,首先要构造数据的逻辑关系

B)表示关系的二维表中各元组的每一个分量还可以分成若干数据项

C)一个关系的属性名表称为关系模式

D)一个关系可以包括多个二维表

<11)C语言源程序名的后缀是

A).exe          B>.C           C>.obj               D>.cp

<12)可在C程序中用做用户标识符的一组标识符是

A)and             B)Date         C)Hi              D)case

    _2007                y-m-d           Dr.Tom             Bigl

(13>以下选项中,合法的一组C语言数值常量是

A>028              B>12.            C>.177              D>0x8A

 . 5e-3             OXa23            4c1.5                 10,000

   -0xf                4.5e0             Oabc               3.e5

<14)以下叙述中正确的是

A)C语言程序将从源程序中第一个函数开始执行

B)可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行

C)C语言规定必须用main作为主函数名,程序将从此开始执行,在此结束

D)main可作为用户标识符,用以命名任意一个函数作为主函数

<15)若在定义语句:

inta,b,c,*p=&c。

之后,接着执行以下选项中的语句,则能正确执行的语句是

A)scanf("%d",a,b,c>。

                     B>scanf("%d%d%d",a,b,c>。

C>scanf("%d",p>。

                         D>scanf("%d",&p>。

(16>以下关于long、int和short类型数据占用内存大小的叙述中正确的是

A>均占4个字节       B)根据数据的大小来决定所占内存的字节数

C)由用户自己定义      D)由C语言编译系统决定

 (17>若变量均已正确定义并赋值,以下合法的C语言赋值语句是

A)x=y==5。

       B>x=n%2.5。

      C>x+n=I。

         D>x=5=4+1。

<18)有以下程序段

    intj。

  floaty。

    charname[50]。

    scanf("%2d%f%s",&j,&y,name>。

    当执行上述程序段,从键盘上输入55566 7777abc后,y的值为

A)55566.0        B)566.0       C)7777.0        D)566777.0

<19)若变量已正确定义,有以下程序段

    i=0。

doprintf("%d,",i>。

while(i++>。

printf("%d\n",i>

其输出结果是

A)0,0      B)0,1      C)1,1      D)程序进入无限循环

<20)有以下计算公式

y=

    (x≥0>

   (x<0>

 

  若程序前面已在命令中包含math.h文件,不能够正确计算上述公式的程序段是

     A)if(x>=0>y=sqrt(x>。

                    B>y=sqrt(x>

elsey=sqrt(-x>。

                         if(x<0>y=sqrt(-x>。

C>if(x>=0>y=sqrt(x>。

                       D>y=sqrt(x>=0?

x:

-x>。

 If(x<0>y=sqrt(-x>。

(21>设有条件表达式:

(EXP>?

i++。

j--,则以下表达式中(EXP>完全等价的是

  A)

=0)    C)

=1)

(22>有以下程序

#include

main(>

{inty=9。

for(。

y>0。

y-->

if(y%3==0> printf("%d",--y>。

}

程序的运行结果是

A)741        B)963         C)852         D)875421

<23)已有定义:

charc。

,程序前面已在命令行中包含ctype.h文件,不能用于判断c中的字符是否为大写字母的表达式是

    A>isupper(c>                     B>’A’<=c<=’Z’

C>’A’<=c&&c<=’Z’               D>c<=(‘2’-32>&&(‘a’-32><=c

(24>有以下程序

  #include

  main(>

  {inti,j,m=55。

for(i=1。

i<=3。

i++>

for(j=3。

j<=i。

j++>m=m%j。

printf("%d\n",m>。

}

程序的运行结果是

A)0           B)1          C)2           D)3

<25)若函数调用时的实参为变量时,以下关于函数形参和实参的叙述中正确的是

    A)函数的实参和其对应的形参共占同一存储单元

B)形参只是形式上的存在,不占用具体存储单元

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

D)函数的形参和实参分别占用不同的存储单元

<26)已知字符’A’的ASCⅡ代码值是65,字符变量c1的值是’A’,c2的值是’D’。

执行语句printf("%d,%d",c1,c2-2>。

后,输出结果是

A)A,B      B)A,68       C)65,66       D)65,68

<27)以下叙述中错误的是

A)改变函数形参的值,不会改变对应实参的值

B)函数可以返回地址值

C)可以给指针变量赋一个整数作为地址值

D)当在程序的开头包含文件stdio.h时,可以给指针变量赋NULL

<28)以下正确的字符串常量是

A)"\\\"        B>’abc’       C>OlympicGames       D>""

(29>设有定义:

charp[]={’1’,’2’,’3’},*q=p。

以下不能计算出一个char型数据所占字节数的表达式是

A)sizeof(p>      B>sizeof(char>    C>sizeof(*q>     D>sizeof(p[0]>

(30>有以下函数

  intaaa(char*s>

  {char*t=s。

while(*t++>。

t--。

return(t-s>。

}

以下关于aaa函数的功能叙述正确的是

A)求字符串s的长度               B)比较两个串的大小

C)将串s复制到串t                D)求字符串s所占字节数

<31)若有定义语句:

inta[3][6]。

,按在内存中的存放顺序,a数组的第10个元素是

A)a[0][4]        B>a[1][3]        C>a[0][3]       D>a[1][4]

(32>有以下程序

#include

voidfun(char **p>

{++p。

   printf("%s\n",*p>。

}

main(>

{char *a[]={"Morning","Afternoon","Evening","Night"}。

fun(a>。

}

程序的运行结果是

A)Afternoon     B)fternoon     C)Morning     D)orning

<33)若有定义语句:

inta[2][3],*p[3]。

,则以下语句中正确的是

A)p=a。

      B>p[0]=a。

      C>p[0]=&a[1][2]。

     D>p[1]=&a。

(34>有以下程序

  #include

  voidfun(int*a,intn>/*fun函数的功能是将a所指数组元素从大到小排序*/

  {intt,i,j。

for(i=0。

i

i++>

for(j=i+1。

j

j++>

if(a[i] {t=a[i]。

a[i]=a[j]。

a[j]=t。

}

}

main(>

{intc[10]={1,2,3,4,5,6,7,8,9,0},i。

fun(c+4,6>。

for(i=0。

i<10。

i++>  printf("%d,",c[i]>。

printf("\n">。

}

程序运行的结果是

A)1,2,3,4,5,6,7,8,9,0,           B>0,9,8,7,6,5,1,2,3,4,

C>0,9,8,7,6,5,4,3,2,1,            D>1,2,3,4,9,8,7,6,5,0,

(35>有以下程序

  #include

  int fun(chars[]>

{intn=0。

while(*s<=’9’&&*s>=’0’>  {n=10*n+*s-’0’。

s++。

}

return(n>。

}

main(>

{chars[10]={’6’,’1’,’*’,’4’,’*’,’9’,’*’,’0’,’*’}。

printf("%d\n",fun(s>>。

}

程序运行的结果是

A)9      B)61490        C)61        D)5

<36)当用户要求输入的字符串中含有空格时,应使用的输入函数是

 A>scanf(>         B>getchar(>        C>gets(>       D>getc(>

(37>以下关于字符串的叙述中正确的是

A)C语言中有字符串类型的常量和变量

B)两个字符串中的字符个数相同时才能进行字符串大小的比较

C)可以用关系运算符对字符串的大小进行比较

D)空串一定比空格打头的字符串小

 

****第38题到41题目暂缺****

 

 

 

 

(42>有以下程序

#include 

void fun(intn,int*p>

{  int  f1,f2。

if(n==1||n==2>    *p=1。

else

{   fun(n-1,&f1>。

     fun(n-2,&f2>。

    *p=f1+f2。

}

}

main(>

{    int    s。

     fun(3,&s>。

      printf("%d\n",s>。

}

程序的运行结果是

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

(43>若程序中有宏定义行:

#define N  100  则以下叙述中正确的是

A>宏定义行中定义了标识符N的值为整数100

B>在编译程序对C源程序进行预处理时用100替换标识符N

C>对C源程序进行编译时用100替换标识符N

D>在运行时用100替换标识符N

(44>以下关于typedef的叙述错误的是

A>用typedef可以增加新类型

B>typedef只是将已存在的类型用一个新的名字来代表

C>用typedef可以为各种类型说明一个新名,但不能用来为变量说明一个新名

D>用typedef为类型说明一个新名,通常可以增加程序的可读性

(45>有以下程序

#include

structtt   

{intx。

structtt*y。

}*p。

structtta[4]={20,a+1,15,a+2,30,a+3,17,a}。

main(>

{inti。

 p=a。

 for(i=1。

i<=2。

i++>  {printf("%d,",p->x>。

  p=p->y。

}

}

程序的运行结果是

A>20,30,      B>30,17      C>15,30,          D>20,15,

(46>有以下程序

#include  

#include  

typedef struct{char name[9]。

char sex。

float score[2]。

 } STU。

STU   f(STU   a>

{     STU   b={"Zhao",'m',85.0,90.0}。

    int i。

strcpy(a.name,b.name>。

a. sex=b.sex。

for(i=0。

i<2。

i++> a.score[i]=b.score[i]。

return  a。

}

main(>

{STU   c={"Qian",'f',95.0,92.0},d。

d=f(c>。

printf("%s,%c,%2.0f,%2.0f\n",d.name,d.sex,d.score[0],d.score[1]>。

}

程序的运行结果是

A>Qian,f,95,92   B>Qian,m,85,90  C>Zhao,m,85,90    D>Zhao,f,95,92

(47>设有以下定义

uniondata

{  int d1。

    float  d2。

  }demo。

则下面叙述中错误的是

A>变量demo与成员d2所占的内存字节数相同

B>变量demo中各成员的地址相同

C>变量demo和各成员的地址相同

D>若给demo.d1赋99后,demo.d2中的值是99.0

(48>有以下程序

#include  

main(>

{  int   a=1,b=2,c=3,x。

  x=(a^b>&c。

  printf("%d\n",x>。

}

程序的运行结果是

A>0       B>1       C>2          D>3

(49>读取二进制文件的函数调用形式为:

fread(buffer,size,count,fp>。

其中buffer代表的是

A>一个文件指针,指向待读取的文件

B>一个整型变量,代表待读取的数据的字节数

C>一个内存块的首地址,代表读入数据存放的地址

D>一个内存块的字节数

(50>有以下程序

#include 

main(>

{FILE   *fp。

 int a[10]={1,2,3,0,0},i。

fp=fopen("d2.dat,"wb">。

fwrite(a,sizeof(int>,5,fp>。

fwrite(a,sizeof(int>,5,fp>。

fclose(fp>。

fp=fopen("d2.dat","rb">。

fread(a,sizeof(int>,10,fp>。

fclose(fp>。

for(i=0。

i<10。

i++>   printf("%d",a[i]>。

}

程序的运行结果是

A>1,2,3,0,0,0,0,0,0,0,                       B>1,2,3,1,2,3,0,0,0,0,

C>123,0,0,0,0,123,0,0,0,0,                   D>1,2,3,0,0,1,2,3,0,0,

二、填空题(每空2分,共40分>

请将每一个空的正确答案写在答题卡[1]至[20]序号的横线上,答在试卷上不得分.

(1>            软件需求规格说明书应具有完整性、无歧义性、正确性、可验证性、可修改性等特性,其中最重要的_[1]_______.

(2>            在两种基本测试方法中,_[2]_______测试的原则之一是保证所测模块中每一个独立路径至少要执行一次.

(3>            线性表的存储结构主要分为顺序存储结构和链式存储结构.队列是一种特殊的线性表,循环队列是队列的_[3]_______存储结构.

(4>            对下列二叉树进行中序遍历的结果为_[4]_______

 

 

 

 

 

(5>            在E-R图中距形表示_[5]_______

(6>            执行以下程序时输入1234567,则输出结果是_[6]_______.

#include    

main(>

{  int  a=1,b。

scanf("%2d%2d",&a&b>。

printf("%d %d\n",a,b>。

}

(7>            以下程序的功能是:

输出a、b、c三个变量中的最小值.请填空。

#include

main(>

{inta,b,c,t1,t2。

scanf("%d%d%d",&a,&b,&c>。

t1=a

_[7]_______。

t2=c

_[8]_______。

printf("%d\n",t2>。

}

(8>            以下程序的输出结果是_[9]_______.

#include  

main(>

{    int n=12345,d。

     while(n!

=0>{ d=n%10。

 printf("%d",d>。

n/=10。

}

}

(9>            有以下程序段,且变量已正确定义和赋值

for(s=1.0,k=1。

k<=n。

k++>      s=s+1.0/(k*(k+1>>。

printf("s=%f\n\n",s>。

请填空,使下面程序段的功能为完全相同

s=1.0。

k=1。

while(_[10]_______>{s=s+1.0/(k*(k+1>>。

_[11]_______。

}

printf("s=%f\n\n",s>。

(10>       以下程序的输出结果是_[12]_______.

#include    

main(>

{   int  i。

    for(i='a'。

i<'f'。

i++,i++>  printf("%c",i-'a'+'A'>。

    printf("\n">。

}

(11>       以下程序的输出结果是_[13]_______.

#include  

#include   

char *fun(char  *t>

{   char     *p=t。

    return(p+strlen(t>/2>。

}

main(>

{   char  *str="abcdefgh"。

    str=fun(str>。

    puts(str>。

}

(12>以下程序中函数f的功能是在数组x的n个数(假定n个数互不相同>中找出最大最小数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换.请填空.

#include   

viod   f(int    x[],int    n>

{    int   p0,p1,i,j,t,m。

     i=j=x[0]。

         p0=p1=0。

     for(m=0。

m

m++>

{   if(x[m]>i>         {i=x[m]。

 p0=m。

}

     else   if(x[m]  {j=x[m]。

 p1=m。

}

}

t=x[p0]。

  x[p0]=x[n-1]。

    x[n-1]=t。

t=x[p1]。

x[p1]=_[14]_______。

_[15]_______=t。

}

main(>

{  int   a[10],u。

   for(u=0。

u<10。

u++>    scanf("%d",&a[u]>。

f(a,10>。

for(u=0。

u<10。

u++>        printf("%d",a[u]>。

printf("\n">。

}

(13>以下程序统计从终端输入的字符中大写字母的个数,num[0]中统计字母A的个数,num[1]中统计字母B的个数,其它依次类推.用#号结束输入,请填空.

#include    

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

当前位置:首页 > 医药卫生 > 中医中药

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1