[计算机类试卷]2007年9月国家二级(C语言)笔试真题试卷及答案与解析.doc
《[计算机类试卷]2007年9月国家二级(C语言)笔试真题试卷及答案与解析.doc》由会员分享,可在线阅读,更多相关《[计算机类试卷]2007年9月国家二级(C语言)笔试真题试卷及答案与解析.doc(37页珍藏版)》请在麦多课文档分享上搜索。
1、2007 年 9月国家二级( C语言)笔试真题试卷及答案与解析 1 软件是指 ( A)程序 ( B)程序和文档 ( C)算法加数据结构 ( D)程序、数据与相关文档的完整集合 2 软件调试的目的是 ( A)发现错误 ( B)改正错误 ( C)改善软件的性能 ( D)验证软件的正确性 3 在面向对象方法中,实现信息隐蔽是依靠 ( A)对象的继承 ( B)对象的多态 ( C)对象的封装 ( D)对象的分类 4 下列叙述中,不符合良好程序设计风格要求的是 ( A)程序的效率第一,清晰第二 ( B)程序的 可读性好 ( C)程序中要有必要的注释。 ( D)输入数据前要有提示信息 5 下列叙述中正确的是
2、 ( A)程序执行的效率与数据的存储结构密切相关 ( B)程序执行的效率只取决于程序的控制结构 ( C)程序执行的效率只取决于所处理的数据量 ( D)以上三种说法都不对 6 下列叙述中正确的是 ( A)数据的逻辑结构与存储结构必定是一一对应的 ( B)由于计算机存储空间是向量式的存储结构,因此,数据的存储结构一定是线性结构 ( C)程序设计语言中的数组一般是顺序存储结构,因此,利用数组只能处理线性结构 ( D)以上三种说法都不对 7 冒泡排序在最坏情况下的比较次数是 ( A) n(n+1)/2 ( B) nlog2n ( C) n(n-1)/2 ( D) n/2 8 一棵二叉树中共有 70个叶
3、子结点与 80个度为 1的结点,则该二叉树中的总结点数为 ( A) 219 ( B) 221 ( C) 229 ( D) 231 9 下列叙述中正确的是 ( A)数据库系统是一个独立的系统,不需要操作系统的支持 ( B)数据库技术的根本目标是要解决数据的共享问题 ( C)数据库管理系统就是数据库系统 ( D)以上三种说法都不对 10 下列叙述中正确的是 ( A)为了建立一个关系,首先要构造数据的逻辑关系 ( B)表示关系的二维表中各元组的每一个分量还可以分成若干数据项 ( C)一个关系的属性名表称为关系模式 ( D)一个关系可以包括多个二维表 11 C语言源程序名的后缀是 ( A) .exe
4、( B) .C ( C) .obj ( D) .cp 12 可在 C程序中用作用户标识符的一组标识符是 ( A) and _2007 ( B) Date y-m-d ( C) Hi Df Tom ( D) case Big1 13 以下选项中,合法的 组 C语言数值常量是 ( A) 028 .5e-3 -Oxf ( B) 12 0Xa23 4.5e0 ( C) 177 4e1.5 0abc ( D) 0x8A 10,000 3.e5 14 以下叙述中正确的是 ( A) C语言程序将从源程序中第一个函数开始执行 ( B)可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行 ( C)
5、C语言规定必须用 main作为主函数名,程序将从此开始执行,在此结束 ( D) main可作为 用户标识符,用以命名任意一个函数作为主函数 15 若在定义语句: int a, b, c, *p= t-; return(t-s); 以下关于 aaa函数的功能的叙述正确的是 ( A)求字符串 s的长度 ( B)比较两个串的大小 ( C)将串 s复制到串 t ( D)求字符串 s所占字节数 31 若有定义语句: int a36;,按在内存中的存放顺序, a数组的第 10个元素是 ( A) a04 ( B) a13 ( C) a03 ( D) a14 32 有以下程序 #include stdio.h
6、 void fun(char *p) +p; printf(“%sn“,*p); main() char *a=“Moming“,“Afternoon“,“Evening“,“Night“; fun(a); 程序的运行结果是 ( A) Afternoon ( B) fternoon ( C) Morning ( D) orning 33 若有定义语句: int a23, *p3,则以下 语句中正确的是 ( A) p=a; ( B) p0=a; ( C) p0= for (i=0; i n-1 ;i+) for 0=i+l; j n; j+) if(ai aj) t=ai; ai=aj; aj=
7、t; main() int c10= 1,2,3,4,5,6,7,8,9,0,i; fun(c+4, 6); for (i=0;i 10; i+) printf(“%d,“, ci); 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 stdio.h int fun(char s) int n=O; while(*s =9 s+; return (n); main() char
8、 s10= 6, 1, *, 4, *, 9, *, 0, *; printf(“%dn“,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 有以下程序 #incl
9、ude stdio.h void fun(char *t, char *s) while(*t!=0) t+; while( (*t+ = *s+ )!=0 ); main() char ss10=“acc“,aa10=“bbxxyy“; fun(ss, aa); printff“%s,%sn“, ss,aa); 程序的运行结果是 ( A) accxyy, bbxxyy ( B) acc, bbxxyy ( C) accxxyy, bbxxyy ( D) accbbxxyy, bbxxyy 39 有以下程序 #include stdio.h #include string.h void fun
10、(char s10,int n) char t; int i j; for (i=0; i n-1; i+) for 0-i+l; jn; j+) /*比较字符串的首字符大小,并交换字符串的首字符 */ if(si0 sj0) t = si0; si0 = sj0; sj0 = t; main() char ss510= “bcc“, “bbcc“, “xy“, “aaaacc“, “aabcc“ ; fun(ss, 5); printf(“%s,%sn“, ss0,ss4); 程序的运行结果是 ( A) xy, aaaacc ( B) aaaacc,xy ( C) xcc,aabcc ( D
11、) acc,xabcc 40 在一个 C源程序文件中所定义的全局变量,其作用域为 ( A)所在文件的全部范围 ( B)所在程序的全部范围 ( C)所在函数的全部范围 ( D)由具体定义位置和 extern说明来决定范围 41 有以下程序 #include stdio.h int a=1; int f(int c) static int a=2; c=c+1; return (a+) + c; main() int i, k=0; for(i=0;i 2;i+) int a=3; k += f(a); k +=a; printf(“%dn“,k); ( A) 14 ( B) 15 ( C) 16
12、 ( D) 17 42 有以下程序 #include stdio.h void fun(int n, int *p) int f1,t2; if(n=1 |n=2) *p=1; else fun(n-1, fun(n-2, *p=f1+f2; main() int s; fun(3, printf(“%dn“, s ); ( A) 2 ( B) 3 ( C) 4 ( D) 5 43 若程序中有宏定义行: #define N 100 则以下叙述中正确的是 ( A)宏定义行中定义了标识符 N的值为整数 100 ( B)在编译程序对 C 源程序进行预处理时用 100替换标识符 N ( C)对 C源程
13、序进行编译时用 100替换标识符 N ( D)在运行时用 100替换标识符 N 44 以下关于 typedef的叙述错误的是 ( A)用 typedef可以增加新类型 ( B) typedef只是将已存在的类型用一个新的名字来代表 ( C)用 typedef可以为各种类型说明一个新名,但不能用来为变量说明一个新名 ( D)用 typedef为类型说明一个新名, 通常可以增加程序的可读性 45 有以下程序 #include stdio.h struct tt int x; struct tt *y; *p; struct tt a4= 20,a+ 1,15,a+2,30,a+3,17,a; ma
14、in() int i; 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 stdio.h #include string.h typedef struct char name9; char sex; float score2; STU; STU f(STU a) STU b=“Zhao“, m, 85.0, 90.0; int i; strcpy(a.name, b.name); a.sex = b.sex;
15、 for (i=0; i 2; i+) a.scorei = b.scorei; return a; main() STU c=“Qian“, T, 95.0, 92.0, d; d=f(c); printf(“%s,%c,%2.0f,%2.0fn“, d.name, 程序的运行结果是 ( A) Qian, f,95,92 ( B) Qian,m,85,90 ( C) Zhao,m,85,90 ( D) Zhao,f,95,92 47 设有以下定义 union data int d1; float d2; demo; 则下面叙述中错误的是 ( A)变量 demo与成员 d2所占的内存字节数相同
16、 ( B)变量 demo中各成员的地址相同 ( C)变量 demo和各成员的地址相同 ( D)若给 demo d1赋 99后, demo d2中的值是 99.0 48 有以下程序 #include stdio.h main() int a=1, b=2, c=3, x; x=(ab) printf(“%dn“,x); 程序的运行结果是 ( A) 0 ( B) 1 ( C) 2 ( D) 3 49 读取二进制文件的函数调用形式为: fread(buffer, size, count, fp);,其中buffer代表的是 ( A)一个文件指针,指向待读取的文件 ( B)一个整型变量 ,代表待读取的
17、数据的字节数 ( C)一个内存块的首地址,代表读入数据存放的地址 ( D) 个内存块的字节数 50 有以下程序 #include stdio.h main() FILE *fp; int a10=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 = fopenCd2.dat“, “rb“); fread(a, sizeof(int), 10, fp); fclose(fp); for (i=0; i 10; i
18、+) printf(“%d,“, ai); ( 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, 51 软件需求规格说明书应具有完整性 、无歧义性、正确性、可验证性、可修改性等特性,其中最重要的是【 】。 52 在两种基本测试方法中,【 】测试的原则之一是保证所测模块中每一个独立路径至少要执行一次。 53 线性表的存储结构主要分为顺序存储结构和链式存储结构。队列是一种特殊的线性表,循环队列是队列的【 】存储结构。 54 对下列二叉树进
19、行中序遍历的结果为【 】。 55 在 E-R图中,矩形表示【 】。 56 执行以下程序时输入 1234567 CR,则输出结果是【 】。 #include stdio h main() int a=1,b; scanf(“%2d%2d“, prinff(“%d %dhn“,a,b); 57 以下程序的输出结果是【 】。 # include stdio.h main() int n=12345, d; while(n!=O) d=n%10; printf(“%d“,d); n/=10; 58 以下程序的输出结果是【 】。 #include stdio.h main() int i; for(i=
20、a; i f; i+,i+) printf(“%c“,i - a + A); printf(“n“); 59 以下程序的输出结果是【 】。 #include stdio.h #include string.h char *fun(char *0 char *p-t; return (p+strlen(t)/2); main() char *str=“abcdefgh“; str=ftm(str); puts(str); 60 执行以下程序的输出结果是【 】。 #include stdio.h main() int i, n4=1; for(i= 1 ;i =3 ;i+) ni=ni-1*2+1
21、; printf(“%d“,ni); 61 以下程序的输出结果是【 】。 #include stdio.h #define M 5 #define N M+M main0 int k; k = NN*5; printf(“%dn“,k); 62 函数 min()的功能是:在带头结点的单链表中查找数据域中值最小的结点。请填空 #include stdio.h struct node int data; struct node *next; ; int min(struct node *first)/*指针 first为链表头指针 */ struct node *p; int m; p=first
22、- next; re=p- data; p=p- next; for( ;p!=NULL;p=【 】 ) if(p- data m ) re=p- data; return m; 63 以下程序的功能是:输出 a、 b、 c三个变量中的最小值。 #include stdio.h main( ) int a,b,c,t 1,t2; scanf(“%d%d%d“, t1=a b ?【 】 ; t2=c t1?【 】 ; printf(“%dn“, t2 ); 64 有以下程序段,且变量已正确定义和赋值 for(s=1.0, k=1; k =; k+) s=s+1.0/(k*(k+1); print
23、f(“s=%fnn“, s); 请填空,使下面程序段的功能与之完全相同 s=1.0; k=1; while(【 】 ) s=s+1.0/(k*(k+1);【 】 ; prinff(“s=%fnn“, s); 65 以下程序中函数 f的功能是在数组 x的 n个数 (假定 n个数互不相同 )中找出最大最小数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换。请填空。 # include stdio.h void f(int x, int n) int p0, p1, i,j,t,m; i=j=xO; p0=p1=O; for(m=0;m n;m+) if( xm i ) i=xm; p0=
- 1.请仔细阅读文档,确保文档完整性,对于不预览、不比对内容而直接下载带来的问题本站不予受理。
- 2.下载的文档,不会出现我们的网址水印。
- 3、该文档所得收入(下载+内容+预览)归上传者、原创作者;如果您是本文档原作者,请点此认领!既往收益都归您。
下载文档到电脑,查找使用更方便
2000 积分 0人已下载
下载 | 加入VIP,交流精品资源 |
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 试卷 2007 国家 二级 语言 笔试 答案 解析 DOC
