论坛首页· 友情链接申请·申请版主· 广告投放· 道具中心· 设为首页· 收藏本站
发新话题
打印

[资料下载] 2008年4月全国计算机等级考试二级C语言程序设

本主题由 Teenits 于 2008-6-12 12:51 设置高亮

2008年4月全国计算机等级考试二级C语言程序设

1、下列叙述中正确的是
  • 算法效率只与问题的规模有关,而与数据的存储结构无关
  • 算法的时间复杂度是指执行算法所需要的计算工作量
  • 数据的逻辑结构与存储结构是一一对应的
  • 算法的时间复杂度与空间复杂度一定相关

2、在结构化程序设计中,模块划分的原则是
  • 各模块应包括尽量多的功能
  • 各模块的规模应尽量大
  • 各模块之间的联系应尽量紧密
  • 模块内具有高内聚度、模块间具有低耦合度

3、下列叙述中正确的是
  • 软件测试的主要目的是发现程序中的错误
  • 软件测试的主要目的是确定程序中错误的位置
  • 为了提高软件测试的效率,最好由程序编制者自己来完成软件测试的工作
  • 软件测试是证明软件没有错误

4、下面选项中不属于面向对象程序设计特征的是
  • 继承性
  • 多态性
  • 类比性
  • 封装性

5、下列对队列的叙述正确的是
  • 队列属于非线性表
  • 队列按“先进后出”原则组织数据
  • 队列在队尾删除数据
  • 队列按“先进先出”原则组织数据

6、对下列二叉树
进行前序遍历的结果为
  • DYBEAFCZX
  • YDEBFZXCA
  • ABDYECFXZ
  • ABCDEFXYZ

7、某二叉树中有n个度为2的结点,则该二叉树中的叶子结点数为
  • n+1
  • n-1
  • 2n
  • n/2

8、在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是
  • 投影
  • 笛卡儿乘积

9、在E-R图中,用来表示实体之间联系的图形是
  • 矩形
  • 椭圆形
  • 菱形
  • 平行四边形

10、下列叙述中错误的是
  • 数据库系统中,数据的物理结构必须与逻辑结构一致
  • 数据库技术的根本目标是要解决数据的共享问题
  • 数据库设计是指在已有数据库管理系统的基础上建立数据库数据库设计是指在已有数据库管理系统的基础上建立数据库
  • 数据库系统需要操作系统的支持

11、算法中,对需要执行的每一步操作,必须给出清楚、严格的规定,这属于算法的
  • 正当性
  • 可行性
  • 确定性
  • 有穷性

12、下列叙述中错误的是
  • 计算机不能直接执行用C语言编写的源程序
  • C程序经C编译程序编译后,生成后缀为.obj的文件是一个二进制文件
  • 后缀为.obj的文件,经连接程序生成后缀为.exe的文件是一个二进制文件
  • 后缀为.obj和.exe的二进制文件都可以直接运行

13、按照C语言规定的用户标识符命名规则,不能出现在标识符中的是
  • 大写字母
  • 连接符
  • 数字字符
  • 下划线

14、以下叙述中错误的是
  • C语言是一种结构化程序设计语言
  • 结构化程序有顺序、分支、循环三种基本结构组成
  • 使用三种基本结构构成的程序只能解决简单问题
  • 结构化程序设计提倡模块化的设计方法

15、对于一个正常运行的C程序,以下叙述中正确的是
  • 程序的执行总是从main函数开始,在main函数结束
  • 程序的执行总是从程序的第一个函数开始,在main函数结束
  • 程序的执行总是从main函数开始,在程序的最后一个函数中结束
  • 程序的执行总是从程序的第一个函数开始,在程序的最后一个函数中结束

16、设变量均已正确定义,若要通过scanf("%d%c%d%c",&a1,&c1,&a2,&c2);语句为变量a1和a2赋数值10和20,为变量c1和c2赋字符X和Y。以下所示的输入形式中正确的是(注:□代表空格字符)
  • 10□X□20□Y〈回车〉
  • 10□X20□Y〈回车〉
  • 10□X〈回车〉
  • 10X〈回车〉20□Y〈回车〉20Y〈回车〉

17、若有代数式(其中e仅代表自然对数的底数,不是变量),则以下能够正确表示该代数式的C语言表达式是
  • sqrt(abs(n^x+e^x))
  • sqrt(fabs(pow(n,x)+pow(x,e)))
  • sqrt(fabs(pow(n,x)+exp(x)))
  • sqrt(fabs(pow(x,n)+exp(x)))

18、设有定义:int k=0;,以下选项的四个表达式中与其他三个表达式的值不相同的是
  • k++
  • k+=1
  • ++k
  • k+1

19、有以下程序,其中%u表示按无符号整数输出
  main()
  {unsigned int x=0xFFFF;   /* x的初值为十六进制数 */
    printf(“%u\n”,x);
  }
  程序运行后的输出结果是
  • -1
  • 65535
  • 32767
  • 0xFFFF

20、设变量x和y均已正确定义并赋值,以下if语句中,在编译时将产生错误信息的是
  • if(x++);
  • if(x>y&&y!=0);
  • if(x>y) x-- else y++;
  • if(y<0) {;} else x++;
21、以下选项中,当x为大于1的奇数时,值为0的表达式

  • x%2==1
  • x/2
  • x%2!=0
  • x%2==0

22、以下叙述中正确的是

  • break语句只能用于switch语句体中
  • continue语句的作用是:使程序的执行流程跳出包含它的所有循环
  • break 语句只能用在循环体内和switch语句体内
  • 在循环体内使用break语句和continue语句的作用相同

23、有以下程序
  main()
  {int k=5,n=0;
  do
  {switch(k)
    {case1:    case3:n+=1; break;
  default;n=0;k--;
  case2:  case4:n+=2;k--;break;
  }
  printf("%d",n);
  }while(k>0&&n<5);
  }

程序运行后的输出结果是

  • 235
  • 0235
  • 02356
  • 2356

24、有以下程序
main()
{
    int i,j;
    for(i=1;i<4;i++)
    {
        for(j=i;j<4;j++) printf("%d*%d=%d ",i,j,i*j);
        printf("\n");
    }
}
程序运行后的输出结果是

  • 1*1=1  1*2=2  1*3=3
    2*1=2  2*2=4
    3*1=3
  • 1*1=1  1*2=2  1*3=3
    2*2=4  2*3=6
    3*3=9
  • 1*1=1
    1*2=2   2*2=4
    1*3=3   2*3=6   3*3=9
  • 1*1=1
    2*1=2   2*2=4
    3*1=3   3*2=6  3*3=9

25、以下合法的字符型常量是

  • "\x13"
  • "\018"
  • "65"
  • "\n"

26、在C语言中,函数返回值的类型最终取决于

  • 函数定义时在函数首部所说明的函数类型
  • return语句中表达式值的类型
  • 调用函数时主函数所传递的实参类型
  • 函数定义时形参的类型

27、已知大写字母A的ASCII码是65,小写字母aASCII码是97,以下不能将变量c中大写字母转换为对应小写字母的语句是

  • c=(c-A)%26+'a'
  • c=c+32
  • c=c-'A'+'a'
  • c=('A'+c)%26-'a'

28、有以下函数
     int fun(char *s)
     {char *t=s;
      while(*t++);
       return(t-s);
  }
该函数的功能是

  • 比较两个字符的大小
  • 计算s所指字符串占用内存字节的个数
  • 计算s所指字符串的长度
  • 将s所指字符串复制到字符串t中

29、设已有定义:float x;则以下对指针变量p进行定义且赋初值的语句中正确的是

  • float  *p=1024;
  • int  *p=(float x);
  • float   p=&x;
  • float *P=&x;

30、有以下程序
#include <stdio.h>
main()
{
int n,*p=NULL;
*p=&n;
printf("Input n:");   scanf("%d",&p);   printf("output n:");  printf("%d\n",p);
}
该程序试图通过指针p为变量n读入数据并输出,但程序有多处错误,以下语句正确的是

  • int n,*p=NULL;
  • *p=&n;
  • scanf("%d",&p);
  • printf("%d\n",p);

31、以下程序中函数f的功能是:当flag为1时,进行有由小到大排序;当flag为0时,进行由大到小排序。
void f(int  b[],int  n,int  flag)
{int  i,j,t;
for(i=0;i<n-1;i++)
    for (j=i+1;j<n;j++)
      if(flag?b>b[j]:b<b[j]) {t=b;b=b[j];b[j]=t; }
}
main()
{int a[10]={5,4,3,2,1,6,7,8,9,10},i;
    f(&a[2],5,0); f(a,5,1);
for(i=0;i<10;i++) printf(“%d,”a);
}
程序运行后的输出结果是

  • 1,2,3,4,5,6,7,8,9,10,
  • 3,4,5,6,7,2,1,8,9,10,
  • 5,4,3,2,1,6,7,8,9,10,
  • 10,9,8,7,6,5,4,3,2,1,

32、有以下程序
void f(int b[])
{int i;
  for(i=2;i<6;i++)  b*=2;
}
main()
{int a[10]={1,2,3,4,5,6,7,8,9,10},i;
f(a);
for(i=0;i<10;i++) printf("%d,",a);
}
程序运行后的输出结果是

  • 1,2,3,4,5,6,7,8,9,10,
  • 1,2,6,8,10,12,7,8,9,10
  • 1,2,3,4,10,12,14,16,9,10,
  • 1,2,6,8,10,12,14,16,9,10,

33、有以下程序
typedef struct{int b,p;}A;
void f(A c)   /*注意:c是结构变量名 */
{int j;
c.b+=1; c.p+=2;
}
main()
{int i;
A  a={1,2};
f(a);
printf("%d,%d\n",a.b,a.p);
}

程序运行后的输出结果是

  • 2,3
  • 2,4
  • 1,4
  • 1,2

34、有以下程序
main()
{int a[4][4]={{1,4,3,2,},{8,6,5,7,},{3,7,2,5,},{4,8,6,1,}},i,j,k,t;
for(i=0;i<4;i++)
  for(j=0;j<3;j++)
    for(k=j+1;k<4;k++)
      if(a[j]>a[k]){t=a[j];a[j]=a[k];a[k]=t;}/*按列排序*/
  for(i=0;i<4;i++)printf(“%d,”,a[j]);
}

程序运行后的输出结果是

  • 1,6,5,7,
  • 8,7,3,1,
  • 4,7,5,2,
  • 1,6,2,1,

35、有以下程序
main()
{int a[4][4]={{1,4,3,2,},{8,6,5,7,},{3,7,2,5,},{4,8,6,1,}},i,k,t;
for(i=0;i<3;i++)
for(k=i+i;k<4;k++) if(a
for(i=0;i<4;i++)printf("%d,",a[0]);
}

程序运行后的输出结果是

  • 6,2,1,1,
  • 6,4,3,2,
  • 1,1,2,6,
  • 2,3,4,6,

36、有以下程序
void f(int  *q)
{int i=0;
  for( ; i<5;i++)(*q)++;
}

main()
{
    int a[5]={1,2,3,4,5},i;
  f(a);
  for(i=0;i<5;i++)printf(“%d,”,a);
}

程序运行后的输出结果是

  • 2,2,3,4,5,
  • 6,2,3,4,5,
  • 1,2,3,4,5,
  • 2,3,4,5,6,

37、#include <string.h>
main()
{char  p[20]={'a','b','c','d'},q[]="abc", r[]="abcde";
strcpy(p+strlen(q),r);  strcat(p,q);
printf("%d%d\n",sizeof(p),strlen(p));
}
程序运行后的输出结果是

  • 20 9
  • 9  9
  • 20  11
  • 11  11

38、有以下程序

#include  <string.h>
main()
{char  p[20]={'a','b','c','d'},q[]="abc", r[]="abcde";
strcat(p,r); Strcpy(p+strlen(q),q);
Printf("%d \n",sizeof(p));
}

程序运行后的输出结果是

  • 9
  • 6
  • 11
  • 7

39、有以下程序
#include <string.h>
main()
void f(char p[][10], int n )  /*  字符串从小到大排序  */
{ char t[10];      int i,j;
  for(i=0;i<n-1;i++)
for(j=i+1;j<n;j++)
   if(strcmp(p,p[j])>0)  {strcpy(t,p);  strcpy(p,p[j]);  strcpy(p,t);  }

}
main()
{char p[5][10]={"abc","aabdfg","abbd","dcdbe","cd"};
f(p,5);
    printf("%d\n",strlen(p[0]));
}
程序运行后的输出结果是

  • 2
  • 4
  • 6
  • 3

40、有以下程序
void f(int  n, int  *r)
{int r1=0;
if(n%3==0)        r1=n/3;
else  if(n%5==0)    r1=n/5;
else  f(--n,&r1);
*r=r1;
}
main()
{int m=7,r;
f(m,&r);    printf("%d\n,r");
}
程序运行后的输出结果是

  • 2
  • 1
  • 3
  • 0

31、以下程序中函数f的功能是:当flag为1时,进行有由小到大排序;当flag为0时,进行由大到小排序。
void f(int  b[],int  n,int  flag)
{int  i,j,t;
for(i=0;i<n-1;i++)
    for (j=i+1;j<n;j++)
      if(flag?b>b[j]:b<b[j]) {t=b;b=b[j];b[j]=t; }
}
main()
{int a[10]={5,4,3,2,1,6,7,8,9,10},i;
    f(&a[2],5,0); f(a,5,1);
for(i=0;i<10;i++) printf(“%d,”a);
}
程序运行后的输出结果是

  • 1,2,3,4,5,6,7,8,9,10,
  • 3,4,5,6,7,2,1,8,9,10,
  • 5,4,3,2,1,6,7,8,9,10,
  • 10,9,8,7,6,5,4,3,2,1,

32、有以下程序
void f(int b[])
{int i;
  for(i=2;i<6;i++)  b*=2;
}
main()
{int a[10]={1,2,3,4,5,6,7,8,9,10},i;
f(a);
for(i=0;i<10;i++) printf("%d,",a);
}
程序运行后的输出结果是

  • 1,2,3,4,5,6,7,8,9,10,
  • 1,2,6,8,10,12,7,8,9,10
  • 1,2,3,4,10,12,14,16,9,10,
  • 1,2,6,8,10,12,14,16,9,10,

33、有以下程序
typedef struct{int b,p;}A;
void f(A c)   /*注意:c是结构变量名 */
{int j;
c.b+=1; c.p+=2;
}
main()
{int i;
A  a={1,2};
f(a);
printf("%d,%d\n",a.b,a.p);
}

程序运行后的输出结果是

  • 2,3
  • 2,4
  • 1,4
  • 1,2

34、有以下程序
main()
{int a[4][4]={{1,4,3,2,},{8,6,5,7,},{3,7,2,5,},{4,8,6,1,}},i,j,k,t;
for(i=0;i<4;i++)
  for(j=0;j<3;j++)
    for(k=j+1;k<4;k++)
      if(a[j]>a[k]){t=a[j];a[j]=a[k];a[k]=t;}/*按列排序*/
  for(i=0;i<4;i++)printf(“%d,”,a[j]);
}

程序运行后的输出结果是

  • 1,6,5,7,
  • 8,7,3,1,
  • 4,7,5,2,
  • 1,6,2,1,

35、有以下程序
main()
{int a[4][4]={{1,4,3,2,},{8,6,5,7,},{3,7,2,5,},{4,8,6,1,}},i,k,t;
for(i=0;i<3;i++)
for(k=i+i;k<4;k++) if(a
for(i=0;i<4;i++)printf("%d,",a[0]);
}

程序运行后的输出结果是

  • 6,2,1,1,
  • 6,4,3,2,
  • 1,1,2,6,
  • 2,3,4,6,

36、有以下程序
void f(int  *q)
{int i=0;
  for( ; i<5;i++)(*q)++;
}

main()
{
    int a[5]={1,2,3,4,5},i;
  f(a);
  for(i=0;i<5;i++)printf(“%d,”,a);
}

程序运行后的输出结果是

  • 2,2,3,4,5,
  • 6,2,3,4,5,
  • 1,2,3,4,5,
  • 2,3,4,5,6,

37、#include <string.h>
main()
{char  p[20]={'a','b','c','d'},q[]="abc", r[]="abcde";
strcpy(p+strlen(q),r);  strcat(p,q);
printf("%d%d\n",sizeof(p),strlen(p));
}
程序运行后的输出结果是

  • 20 9
  • 9  9
  • 20  11
  • 11  11

38、有以下程序

#include  <string.h>
main()
{char  p[20]={'a','b','c','d'},q[]="abc", r[]="abcde";
strcat(p,r); Strcpy(p+strlen(q),q);
Printf("%d \n",sizeof(p));
}

程序运行后的输出结果是

  • 9
  • 6
  • 11
  • 7

39、有以下程序
#include <string.h>
main()
void f(char p[][10], int n )  /*  字符串从小到大排序  */
{ char t[10];      int i,j;
  for(i=0;i<n-1;i++)
for(j=i+1;j<n;j++)
   if(strcmp(p,p[j])>0)  {strcpy(t,p);  strcpy(p,p[j]);  strcpy(p,t);  }

}
main()
{char p[5][10]={"abc","aabdfg","abbd","dcdbe","cd"};
f(p,5);
    printf("%d\n",strlen(p[0]));
}
程序运行后的输出结果是

  • 2
  • 4
  • 6
  • 3

40、有以下程序
void f(int  n, int  *r)
{int r1=0;
if(n%3==0)        r1=n/3;
else  if(n%5==0)    r1=n/5;
else  f(--n,&r1);
*r=r1;
}
main()
{int m=7,r;
f(m,&r);    printf("%d\n,r");
}
程序运行后的输出结果是

  • 2
  • 1
  • 3
  • 0

TOP

其实这些二级考试很简单的,只要你懂了~
相濡以沫,不若相忘于江湖

TOP

发新话题