(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)有以下程序段
int j; float y; char name[50];
scanf(\当执行上述程序段,从键盘上输入55566 7777abc后,y的值为 储单元 B)0,9,8,7,6,5,1,2,3,4, C) (26)已知字符’A’的ASCⅡ代码值是0,9,8,7,6,5,4,3,2,1, 65,字符变量c1的值是’A’,c2的值是’D)1,2,3,4,9,8,7,6,5,0, D’。执行语句printf(\(35)有以下程序 后,输出结果是 A)A,B B)A,#include 68 C)65,66 D)65,68 int fun(char s[]) (27)以下叙述中错误的是 A)改变{int n=0; 函数形参的值,不会改变对应实参的值 while(*s<=’9’&&*s>=’0’) {n=10*n+*s-’B)函数可以返回地址值 C)可以给指针0’;s++;} 变量赋一个整数作为地址值 return(n);} D)当在程序的开头包含文件stdio.h时,main() 可以给指针变量赋NULL {char s[10]={’6’,’1’,’*’,’4’,’(28)以下正确的字符串常量是 A)*’,’9’,’*’,’0’,’*’}; \’abc’ C)OlympicGames printf(\程序运行的A)55566.0 B)566.0 C)7777.0 D)566777.0 (19)若变量已正确定义,有以下程序段 i=0;
do printf(\
printf(\其输出结果是 A)0,0 B)0,1 C)1,1 D)程序进入无限循环
(20)有以下计算公式 若程序前面已
在命令中包含math.h文件,不能够正确
计算上述公式的程序段是
A)if(x>=0) y=sqrt(x);
B)y=sqrt(x)else y=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)(EXP= =0) B)(EXP!=0) C)(EXP= =1) D)(EXP!=1) (22)有以下程序 #include main() {int y=9; for( y>0;y--) if(y%3= =0) printf(\程序的运行结果是 A)741 B)963 C)852 D)875421 (23)已有定义:char c; ,程序前面已在命令行中包含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() {int i,j,m=55; for(i=1;i<=3;i++) for(j=3;j<=i;j++) m=m%j; printf(\程序的运行结果是 A)0 B)1 C)2 D)3 (25)若函数调用时的实参为变量时,以下关于函数形参和实参的叙述中正确的是 A)函数的实参和其对应的形参共占同一存储单元 B)形参只是形式上的存在,不占用具体存储单元 C)同名的实参和形参占同一存储单元 D)函数的形参和实参分别占用不同的存D)\(29)设有定义:char p[]={’1’,’2’,’3’},*q=p; ,以下不能计算出一个char型数据所占字节数的表达式是 A)sizeof(p) B)sizeof(char) C) sizeof(*q) D)sizeof(p[0]) (30)有以下函数 int aaa(char *s) {char *t=s; while(*t++); t--;
return(t-s);} 以下关于aaa函数的
功能叙述正确的是
A)求字符串s的长度 B)比较两个串的
大小 C)将串s复制到串t D)求字符
串s所占字节数
(31)若有定义语句:int a[3][6]; ,
按在内存中的存放顺序,a数组的第10个
元素是
A)a[0][4] B)a[1][3] C)a[0][3]
D)a[1][4]
(32)有以下程序
#include
void fun(char **p)
{++p; printf(\
main()
{char
*a[]={\
g\
fun(a);} 程序的运行结果是
A)Afternoon B)fternoon C)Morning D)
orning
33)若有定义语句:int a[2][3],*p[3]; ,
则以下语句中正确的是
A)p=a; B)p[0]=a; C) p[0]=&a[1][2]; D)p[1]=&a; (34)有以下程序 #include void fun(int *a,int n)/*fun函数的功能是将a所指数组元素从大到小排序*/ {int t,i,j; for(i=0;i {int c[10]={1,2,3,4,5,6,7,8,9,0},i; fun(c+4,6); for (i=0;i<10;i++) printf(\ printf(\程序运行的结果是 A)1,2,3,4,5,6,7,8,9,0, 11 结果是 A)9 B)61490 C)61 D)5 36)当用户要求输入的字符串中含有空格时,应使用的输入函数是 A)scanf() B)getchar() C)gets() D)getc() (37)以下关于字符串的叙述中正确的是 A)C语言中有字符串类型的常量和变量 B)两个字符串中的字符个数相同时才能进行字符串大小的比较 C)可以用关系运算符对字符串的大小进 行比较 D)空串一定比空格打头的字 符串小 (38)有以下程序: #include void fun(char *t,char *s) {while(*t!=0)t++; while((*t++=*s++)!=0);} main() { char ss[10]=”acc”,aa[10]=”bbxxyy”; fun(ss,aa); printf(“%s,%s\\n”,ss,aa);}程序运行 结果是 A) accxyy , bbxxyy B) acc, bbxxyy C) accxxyy,bbxxyy D) accbbxxyy,bbxxyy (39)有以下程序 #include #include void fun(char s[][10],int n) {char t;int i,j; for(i=0;i for(j=i+1,j 字符大小,并交换字符串的首字符 */ if(s[0])>s[j][0]{t=s[0];s[0]=s[j][0 ];s[j][0]=t;}} main() {char ss[5][10]={“bcc”,”bbcc”,”xy”,”aaaacc””aabcc”} fun(ss,5); printf(“%s,%s\\n”,ss[0],ss[4]);} 程序运行结果是 A) xy,aaaacc B) aaaacc,xy C) xcc,aabcc D) acc,xabcc (40) 在一个C语言源程序文件中所定义的全局变量,其作用域为: A) 所在文件的全部范围 B) 所在程序的 全部范围 C) 所在函数的全部范围 D) 由具体定义 位置和extern 说明来决定范围 (41)有以下程序 #include 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(“%d\\n”,k);} 程序运行结果是 A) 14 B) 15 C) 16 D) 17 {STU c={\/ \\ \\ d=f(c); A D G printf(\/ / \\ B H P ,d.sex,d.score[0],d.score[1]);} 程 序的运行结果是 (5) 在E-R图中距形表示_[5]_______ A)Qian,f,95,92 B)Qian,m,85,90 (6) 执行以下程序时输入1234567,则输 C)Zhao,m,85,90 D)Zhao,f,95,92 出结果是_[6]_______. (47)设有以下定义 #include union data main() { int d1; float d2; }demo;则下面叙述 { int a=1,b; 中错误的是 scanf(\ A)变量demo与成员d2所占的内存字节数 (42)有以下程序 n\ 相同 B)变量demo中各成员的地址相 #include (7) 以下程序的功能是:输出a、b、c三 同 void fun(int n,int *p) 个变量中的最小值.请填空。 C)变量demo和各成员的地址相同 { 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(\程序的运行结果是 A)2 B)3 C)4 D)5 (43)若程序中有宏定义行:#define N 100 则以下叙述中正确的是 A)宏定义行中定义了标识符N的值为整数100 B)在编译程序对C源程序进行预处理时用100替换标识符N C) 对C源程序进行编译时用100替换标识 D)在运行时用100替换标识符N (44)以下关于typedef的叙述错误的是 A)用typedef可以增加新类型 B)typedef只是将已存在的类型用一个新的名字来代表C)用typedef可以为各种类型说明一个新名,但不能用来为变量说明一个新名 D)用typedef为类型说明一个新名,通常可以增加程序的可读性 (45)有以下程序 #include struct tt {int x;struct tt *y;} *p; struct tt a[4]={20,a+1,15,a+2,30,a+3,17,a}; main() { int i; p=a; for(i=1;i<=2;i++) {printf(\程序的运行结果是 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={\int i; strcpy(a.name,b.name); a. sex=b.sex; for(i=0;i<2;i++) a.score=b.score; return a;} main() D)若给demo.d1赋99后, demo.d2中的值 是99.0 (48)有以下程序 #include main() { int a=1,b=2,c=3,x; x=(a^b)&c; printf(\程 序的运行结果是 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(\ fwrite(a,sizeof(int),5,fp); fwrite(a,sizeof(int),5,fp); fclose(fp); fp=fopen(\ fread(a,sizeof(int),10,fp); fclose(fp); for(i=0;i<10;i++) printf(\ 程序的运行结果是 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) 软件需求规格说明书应具有完整性、 无歧义性、正确性、可验证性、可修改性 等特性,其中最重要的_[1]_______. (2) 在两种基本测试方法中, _[2]_______测试的原则之一是保证所测 模块中每一个独立路径至少要执行一次. (3) 线性表的存储结构主要分为顺序存 储结构和链式存储结构.队列是一种特殊 的线性表,循环队列是队列的 _[3]_______存储结构. (4) 对下列二叉树进行中序遍历的结果 为_[4]_______ F / \\ C E 12 #include main() { int a,b,c,t1,t2; scanf(\ t1=a t2=c printf(\ (8) 以下程序的输出结果是_[9]_______. #include main() { int n=12345,d; while(n!=0){ d=n; printf(\ n/=10;}} (9) 有以下程序段,且变量已正确定义和 赋值 for(s=1.0,k=1;k<=n;k++) s=s+1.0/(k*(k+1)); printf(\ 请填空,使下面程序段的功能为完全相同 s=1.0;k=1; while(_[10]_______){ s=s+1.0/(k*(k+ 1)); _[11]_______;} printf(\ (10) 以下程序的输出结果是 _[12]_______. #include main() { int i; for(i='a';i<'f';i++,i++) printf(\ printf(\ (11) 以下程序的输出结果是 _[13]_______. #include #include char *fun(char *t) { char *p=t; return(p+strlen(t)/2);} main() { char *str=\ 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 { if(x[m]>i) {i=x[m]; p0=m;} else if(x[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(\f(a,10); for(u=0;u<10;u++) printf(\printf(\ (13)以下程序统计从终端输入的字符中大写字母的个数,num[0]中统计字母A的个数,num[1]中统计字母B的个数,其它依次类推.用#号结束输入,请填空. #include #include main() { int num[26]={0},i; char c; while((_[16]_______)!='#') if(isupper(c)) num[c-‘A’]+= _[17]_______; for(i=0;i<26;i++) Printf(\(14)执行以下程序的输出结果是_[18]_______. #include main() { int i,n[4]={1}; for(i=1;i<=3;i++) { n=n[i-1]*2+1; printf(\(15) 以下程序的输出结果是_[19]_______. #include #define M 5 #define N M+M main() { int k; k=N*N*5; printf(\ (16)函数main()的功能是:在带头结点的单链表中查找数据域中值最小的结点.请填空 #include struct node { int data; struct node *next;}; int min(struct node *first)/*指针first为链表头指针*/ { strct node *p; int m; p=first->next; m=p->data;p=p->next; for(;p!=NULL;p=_[20]_______) if(p->datadata; return m;} 2007年4月二级C语言笔试真题及答案 一选择题 (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) DYBEAFCZX B) YDEBFZXCA C) ABDYECFXZ D) ABCDEFXYZ (7) 某二叉树中有n个度为2的结点,则该二叉树中的叶子结点为 A) n+1 B) n-1 C) 2n D) n/2 (8) 在下列关系运算中,不改变关系表中的属性个数但能减少元组个数的是 A) 并 B)交 C)投影 D)笛卡儿乘积 (9) 在E-R图中,用来表示实体之间联系的图形是 A) 矩形 B)椭圆形 C)菱形 D)平行四边形 (10)下列叙述中错误的是 A) 在数据库系统中,数据的物理结构必须与逻辑结构一致 B)数据库技术的根本目标是要解决数据的共享问题 C)数据库设计是指在已有数据库管理系统的基础上建立数据库 D)数据库系统需要操作系统的支持 (11)算法中,对需要执行的每一步操作,必须给出清楚、严格的规定,这属于算法的 A)正当性 B)可行性 C)确定性 D)有穷性 (12)下列叙述中错误的是 A)计算机不能直接执行用C语言编写的源程序 B)C程序经C编译后,生成后缀为.obj的文件是一个二进制文件C)后缀为.obj的文件,经连接程序生成后缀为.exe的文件是一个二进制文件 D)后缀为.obj和.exe的二进制文件都可以直接运行 (13)按照C语言规定的用户标识符命名规则,不能出现在标识符中的是 A)大写字母 B)连接符 C)数字字符 D)下划线 (14)以下叙述中错误的是 A)C语言是一种结构化程序设计语言B)结构化程序有顺序、分支、循环三种基本结构组成 C)使用三种基本结构构成的程序只能解决简单问题D)结构化程序设计提倡模块化的设计方法 13 (15)对于一个正常运行的C程序,以下叙述中正确的是 A)程序的执行总是从main函数开始,在main函数结束B)程序的执行总是从程序的第一个函数开始,在main函数结束 C)程序的执行总是从main函数开始,在程序的最后一个函数中结束D)程序的执行总是从程序的第一个函数开始,在程序的最后一个函数中结束 (16)设变量均已正确定义,若要通过scanf(“%d%c%d%c”,&a1,&c1,&a2,&c2);语句为变量a1和a2赋数值10和20,为变量c1和c2赋字符X和Y。以下所示的输入形式正确的是(注:□代表空格字符) A)10□X□20□Y〈回车〉 B)10□X20□Y〈回车〉 C)10□X〈回车〉D)10X〈回车〉20□Y〈回车〉 20Y〈回车〉 (17)若有代数式(其中e仅代表自然对数的底数,不是变量),则以下能够正确表示该代数式的C语言表达式是 A)sqrt(abs(n^x+e^x)) B)sqrt(fabs(pow(n,x)+pow(x,e))) C)sqrt(fabs(pow(n,x)+exp(x,e))) D) sqrt(fabs(pow(x,n n)+exp(x))) (18)设有定义:int k=0;,以下选项的四个表达式中与其他三个表达式的值不相同的是 A)k++ B)k+=1 C)++k D)k+1 (19)有以下程序,其中%u表示按无呼号整数输出 Main() {unsigned int x=0xFFFF;/* x的初值为十六进制数 */ Printf(“%u\\n”,x);} 程序运行后的输出结果是 A)-1 B)65535 C)32767 D)0XFFFF (20)设变量x和y均已正确定义并赋值,以下if语句中,在编译时将产生错误信息的是 A)if(x++) B)if(x>y&y!=0); C)if(x>y)x- - D)if(y<0) {;}else y++: else x++; (21)以下选项中,当x为大于1的奇数时,值为0的表达式 A)x%2==1 B)x/2 C)x%2!=0 D)x%2==0 (22)以下叙述中正确的是 A)break语句只能用于switch语句题中 B)continue语句的作用是:使程序的执行流程跳出包含它的所有循环 C)break 语句只能用在循环体内和switch语句体内 D)在循环体内使用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);} 程序运行后的输出结果是 A)235 B)0235 C)02356 D)2356 (24)有以下程序 mian() {int i,j; for(i=1;i<4;i++) if(a[j][ i]>a[k][ i]){t=a[j][ i];a[j][ i ]=a[k][ i ];a[k][ i]=t;}/*按列排序*/ for(i=0;i<4;i++)printf(“%d,”,a[ i ][j]);} (43) 有一个名为init.txt的文件,内容如下: #define HDY(A,B) A/B # define PRINT(Y) Printf(“y=%d\\n.,Y) {for(j=i;j<4;j++) printf(“%d*%d=%d “,i,j,i*j); Printf(“\\n”);}}程序运行后的输出结果是 *p=&n; Printf(“Input n:”); scanf(“%d”,&p); printf(“output n:”); printf(“%d\\n”,p);} 该程序试图通过指针p为变量n读入数据并输出,但程序有多处错误,以下语句正确的是 A)int n,*p=NULL; B)*p=&n; C)scanf(“%d”,&p) D)printf(“%d\\n”,p); (31)以下程序中函数f的功能是:当flag为4时,进行有小到大排序;当flag为0时,进行由大到小排序。 void f(int b[],int n,int flag) {int i,j,t; for(i=0;i for (j=i+1;j if(flag?b[ i ]>b[j]:b[ i ]} 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[ i ]);} 程序运行后的输出结果是 A)1,2,3,4,5,6,7,8,9,10, B)3,4,5,6,7,2,1,8,9,10, C)5,4,3,2,1,6,7,8,9,10, D)10,9,8,7,6,5,4,3,2,1, (32)有以下程序 void f(int b[]) {int I; for(i=2;i<6;i++) b[ i ]*=2;} main() {int a[10]={1,2,3,4,5,6,7,8,9,10},i; for(i=0;i<10;i++) printf(“%d,”,a[ i ]);} 程序运行后的输出结果是 A)1,2,3,4,5,6,7,8,9,10, B)1,2,6,8,10,12,7,8,9,10 C)1,2,3,4,10,12,14,16,9,10, D)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 printf(“%d,%d\\n”,a.b,a.p);} 程序运行后的输出结果是 A)2,3 B)2,4 C)1,4 D)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++) 程序运行后的输出结果是 A)1,6,5,7, B)8,7,3,1, C)4,7,5,2, D)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[ i ][ i ]for(i=0;i<4;i++)printf(“%d,”,a[0][ i ]);} 程序运行后的输出结果是 A)6,2,1,1, B)6,4,3,2, C)1,1,2,6, D)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; for(i=0;i<5;i++)printf(“%d,”,a[ i ]);}程序运行后的输出结果是 A)2,2,3,4,5, B)6,2,3,4,5, C)2,3,4,5,6, (37) 有以下程序 #include 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)); }程序运行后的输出结果是 A)20 9 B)9 9 C)20 11 D)11 11 (38) 有以下程序 #include 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)); } 程序运行后的输出结果是 A)9 B)6 C)11 D)7 (39) 有以下程序 #include main() { char p[20]={‘a’,’b’,’c’,’d’}, q[]=”abc”, r[]=”abcde”; Strcat(p,r); strcpy(p+strlen(q),q); Printf(“%d\\n”,strlen(p));} 程序运行后的输出结果是 A) 9 B) 6 C) 11 D) 7 ***********************else {int a=7 ;t+=a++;} return t+a++;} main() {int s=a,i=0; for(;i〈2;i++ 〉 s+=f(i); printf (“%d\\n”,s);} 程序运行后的输出结果是 A)24 B)28 C)32 D)36 14 有以下程序 #include “init.txt” main() {int a=1,b=2,c=3,d=4,k; K=HDY(a+c,b+d); PRINT(K);}下面针对该程序的叙述正确的是 A)编译有错 B)运行出错 C)运行结果为 y=0 D) 运行结果为 y=6 (44) 有以下程序 Main() {char ch[]=“uvwxyz”,*pc; Pc=ch; printf(“%c\\n”,*(pc+5)); }程序运行后的输出结果是 A)z B)0 C)元素ch[5]地址 D)字符y的地址 **********************(45) 有以下程序 struct S {int n; int a[20];}; void f(struct S *P) {int i,j,t; for(i=0;in-1;i++) for(j=j+1;jn-1;j++) 程序运行后的输出结果是 A)3 B)4 C)5 D)6 (49)有以下程序 #include Main() {FILE *fp; int I,a[6]={1,2,3,4,5,6}; fp=fopen(“d2.dat”,”w”); fprintf(fp,”%d%d\\n”,a[0],a[1],a[2]); fprintf(fp, “%d%d\\n”,a[3],a[4],a[5]); fclose(fp); fp=fopen(“d2.dat”,”r”); fscanf(fp,” “%d%d\\n”,&k,&n); printf(“%d%d\\n”,k,n); fclose(fp);} 程序运行后的输出结果是 A)1 2 B)1 4 C)123 4 D) 123 456 (50)有以下程序 #include main () {fILE *fp; int I,a[6]={1,2,3,4,5,6k}; fp=fopen(“d3.dat”,”w+b”); fwrite(a,size(int),6,fp); fseek(fp,sizeof(int)*3,SEEK SET);/*该语句使读文件的位置指针从文件头向后移动3个int型数据*/ fread(a,sizeof(int),3,fp); fclose(fp); for(i=0;i<6;i++) printf(“%d,”,a[ i]);}程序运行后的输出结果是 A)4,5,6,4,5,6, B)1,2,3,4,5,6, C)4,5,6,1,2,3, D)6,5,4,3,2,1, 二.填空题(每空2分,共40分) (1) 在深度为7的满二叉树中,度为2的结点个数为_________。 (2) 软件测试分为白箱(盒)测试和黑箱(盒)测试,等价类划分法属于__________ 测试。 (3) 在数据库系统中,实现各种数据管理功能的核心软件称为 数据库管理系统______。 (4) 软件生命周期可分为多个阶段,一般分为定义阶段、开发阶段和维护阶段。编码和测试属于 _______阶段。 (5)在结构化分析使用的数据流图 (DFD)中,利用 _________ 对其中的图形元素进行确切解释。 (6)执行以下程序后的输出结果是 __________ 。 main() {int a=10; a=(3*5,a+4); printf(“a=%d\\n”,a);} (7) 当执行以下程序时,输入 1234567890<回车>,则其中while循环体将执行___________次。 #include main() {char ch; While((ch=getchar())==’0’) printf(“#”);} (8) 以下程序的运行结果是 _________ 。 int k=0; void fun(int m) { m+=k; k+=m; printf(“m=%d\\n k=%d ”,m,k++);} main() { int i=4; fun(i++); printf(“i=%d k=%d\\n”,i,k);} (9) 以下程序的运行结果是__________ 。 main() {int a=2,b=7,c=5; Switch(a>0) {case 1:switch(b<0) {case 1:switch(“@”); break; Case 2: printf(“!”); break;} Case 0: switch(c==5) { case 0: printf(“*”); break; Case 1: printf(“#”); break; Case 2: printf(“$”); break;} default : printf(“&”);} Printf(“\\n”);} (10)以下程序的输出结果是 ____________ # include main() { printf(“%d\\n”,strlen(“IBM\\n012\\1\\\\”));} (11)已定义char ch=”$”;int i=1,j;执行j=!ch&&i++以后,i的值为 ___________ (12)以下程序的输出结果是 ________ # include main() { char a[]={‘\\1’,’\\2’,’\\3’,’\\4’,’\\0’}; Printf(“%d %d\\n”,sizeof ,srelen );} (13)设有定义语句:int a[][3]={{0},{1},{2}};,则数组元素a[1][2]的值为 ________ *********(14)以下程序的功能是:求出数组x中各相邻两个元素的和,依次存放到a数组中,然后输出,请填空。 Main() {int x[10],a[9],I; For (i=0;i<10;i++) Scanf(“%d”,&x[ i]); For( _________ i<10;i++) A[i-1]=x[ i]+ _____________ For(i=0;i<9;i++) Printf(“%d”,a[ i]); Printf(“\\n”); (15) 以下程序的功能是:利用指针指向三个整型变量,并通过指针运算找出三个数中的最大值,输出到屏幕上,请填空:Main() {int x,y,z,max,*px,*py,*pz,*pmax; Scanf(“%d%d%d”,&x,&y,&z); Px=&x; Py=&y; Pz=&z; Pmax=&max; __________________ If(*pmax<*py)*pmax=*py; If(*pmax<*pz)*pmax=*pz; Printf(“max=%d\\n”,max);} (16)以下程序的输出结果是 ____________ Int fun(int*x,int n) {if(n==0) Return x[0]; Else return x[0]+fun(x+1,n-1);} Main() {int a[]={1,2,3,4,5,6,7}; Printf(“%d\\n”,fun(a,3));} (17)以下程序的输出结果是 ______________ # include Main() {char *s1,*s2,m; S1=s2=(char*)malloc(sizeof(char)); *s1=15;*s2=20; M=*s1+*s2; Printf(“%d\\n”,m);} (18)设有说明 Struct DATE{int year;int month; int day;}; 请写出一条定义语句,该语句定义d为上述结构体变量,并同时为其成员year、month、day 依次赋初值2006、10、1: ____________; ***********(19) 设有定义:FILE*fw;,请将以下打开文件的语句补充完整,以便可以向文本文件readme.txt的最后续写内容。 fw=fopen(“readme.txt”, 2006年9月二级C语言笔试真题及答案 (1)下列选项中不符合良好程序设计风格的是________。 A)源程序要文档化 B)数据说明的次序要规范化 C)避免滥用goto语句 D)模块设计要保证高耦合、高内聚 (2)从工程管理角度,软件设计一般分为两步完成,它们是________。 A)概要设计与详细设计 B)数据设计与接口设计C)软件结构设计与数据设计 D)过程设计与数据设计 (3)下列选项中不属于软件生命周期开发阶段任务的是________。 15 A)软件测试 B)概要设计 C)软件维护 D)详细设计 (4)在数据库系统中,用户所见的数据模式为________。 A)概念模式 B)外模式 C)内模式 D)物理模式 (5)数据库设计的四个阶段是:需求分析、概念设计、逻辑设计和________。 A)编码设计 B)测试阶段 C)运行阶段 D)物理设计 |************(6)设有如下三个关系表 下列操作中正确的是________。 (7)下列叙述中正确的是________。 A)一个算法的空间复杂度大,则其时间复杂度也必定大 B)一个算法的空间复杂度大,则其时间复杂度必定小 C)一个算法的时间复杂度大,则其空间复杂度必定小 D)上述三种说法都不对 (8)在长度为64的有序线性表中进行顺序查找,最环境情况下需要比较的次数为________。 A)63 B)64 C)6 D)7 (9)数据库技术的根本目标是要解决数据的________。 A)存储问题 B)共享问题 C)安全问题 D)保护问题 *****************(10)对下列二叉树进行中序遍历的结果是________。 A)ACBDFEG B)ACBDFGE C)ABDCGEF D)FCADBEG (11)下列叙述中错误的是________。 A)一个C语言程序只能实现一种算法B)C程序可以由多个程序文件组成 C)C程序可以由一个或多个函数组成D)一个C函数可以单独作为一个C程序文件存在 (12)下列叙述中正确的是________。 A)每个C程序文件中都必须有一个main()函数B)在C程序中main()函数的位置是固定的 C)C程序可以由一个或多个函数组成 D)在C程序的函数中不能定义另一个函数 (13)下列定义变量的语句中错误的是________。A)int _int; B)double int_; C)char For; D)float USS (14)若变量x、y已正确定义并赋值,以下符合C语言语法的表达式是________。 A)++x,y=x-- B)x+1=y C)x=x+10=x+y D)double(x)/10 (15)以下关于逻辑运算符两侧运算对象的叙述中正确的是________。 A)只能是整数0或1 B)只能是整数0或非0的整数 C)可以是结构体类型的数据 D)可是任意合法的表达式 (16)若有定义int x,y;并已正确给变量赋值,则以下选项中与表达式(x-y)?(x++): (y++)中的条件表达式(x-y等 价的是________。 A)(x-y>0) B)(x-y<0) C)(x-y<║x-y>0) D)(x-y==0 (17)有以下程序 main() {int x,y,z; x=y=1; z=x++,y++,++y; printf(\程序运行后的输出结果是________。
相关推荐: