公共基础知识 一、选择题 (1)下列关于栈的叙述正确的是 A)栈是非线性结构 B)栈是一种树状结构 C)栈具有先进先出的特征 D)栈具有后进先出的特征 (2)结构化程序设计所规定的三种基本控制结构是 A)输入、处理、输出 B)树形、网形、环形 C)顺序、选择、循环 D)主程序、子程序、函数 (3)结构化程序设计的一种基本方法是 A)筛选法 B)递归法 C)归纳法 D)逐步求精法 (4)如果对一个关系实施了一种关系运算后得到了一个新的关系,而且新的关系中属性个数少于原来关系中属性个数,这说明所实施的运算关系是:A)选择 B)投影 C)连接 D)并 二、填空题 1.对于输入为N个数进行快速排序算法的平均时间复杂度是( ) 2.在面向对象方法学中,直接反映了用户对目标系统的要求的模型是( ) 3.软件测试方法中,黑盒测试个白盒测试法是常用的方法,其中黑盒测试法主要是用于测试( ) 4.关系型数据库管理系统中存储与管理数据的基本形式是( ) C语言程序设计 一、选择题 (1)以下程序的输入结果是 main( ) { int i=010,j=10,k=x10; printf("%d,%d,%d\n",i,j,k); } A)8,10,16 B)8,10,10 C)10,10,10 D)10,10,16 (2)指针s所指字符串的长度 char *s="\t\ "Name\ \ Address \n"; A)说法不合法 B)19 C)18 D)15 (3)C语言中最简单的数据类型包括 A)整型、实型、逻辑型 B)整型、实型、字符型 C)整型、字符型、逻辑型 D)整型、实型、逻辑型、字符型 (4)为表示关系x大于等于y大于等于z,应使用C语言表达式 A)(x>=Y)&&(Y>=z) B)(x>=Y)AND(y>=z) C)(x>=Y>=z) D)(x>=Y)&(Y>=z) (5)下列对C语言字符数组的描述中错误的是 A)字符数组可以存放字符串 B)字符数组中的字符串可以整体输入、输出 C)可以在赋值语句中通过赋值运算符“=”对字符数组整体赋值 D)不可以用关系运算符对字符数组中的字符串进行比较 (6)以下说法中正确的是 A)C语言程序总是从第一个定义的函数开始执行 B)在C语言程序中,要调用的函数必须在main()函数中定义 C)C语言程序总是从main()函数开始执行 D)C语言程序中的main()函数必须放在程序的开始部分 (7)以下程序段的输出结果是 int x=3; do { printf("%3d",x-=2); } while(!(- -x)); A)1 B)30 C)1 -2 D)死循环 (8)设有如下定义: char *aa[2]={"abcd","ABCD"}; 则以下说法中正确的是 A)aa数组元素的值分别是"abcd"和"ABCD" B)aa是指针变量,它指向含有两个数组元素的字符型一维数组 C)aa数组的两个元素分别存放的是含有4个字符的一维字符数组的首地址 D)aa数组的两个元素中各自存放了字符'a'和'A'的地址 (9)设有以下定义: int a[4][3]={1,2,3,4,5,6,7,8,9,10,11,12}; int (*prt)[3]=a, * p=a[0]; 则下列能够正确表示数组元素a[1][2]的表达式是 A)*((* prt + 1)[2]) B)*(*(p+5)) C)(* prt + 1)+2 D)*(*(a+1)+2) (10)以下程序的输出结果是 fut( int * *s,int p[2][3]) { * *s=p[1][1]; } main( ) { int a[2][3]={1,3,5,7,9,11},*P; p=(int * )malloc(sizeof(int)); fut(&p,a); print("%\n",*p); } A)1 B)7 C)9 D)11 二、填空题 (1)表示条件:10(2)下列程序的输出结果是( ) #include main( ) { char b[ ]="ABCDEFG"; char *chp=&b[7]; while(- -chp>&b[0]) putchar(*chp); putchar("\n"); } (3)下列程序的输出结果是( ) int ast( int x,int Y,int * cp,int * dp) { * cp=x+y; * dp=x-y; } main( ) { int a,b,c,d; a=4;b=3; ast(a,b,&c,&d); print("% d % d \ n",c,d); } (4)阅读程序: main( ) { char str1[ ]="how do you do",str2[10]; char *p1=str1,*p2=str2; scanf("% s",p2); printf("%s",p2); printf("%s\n",p1); } 运行上面的程序,输入字符串 HOW DO YOU DO 则程序的输出结果是( ) (5)以下程序由终端键盘输入一个文件名,然后把从终端键盘输入的字符依次存放到该文件中,用#作为结束输入的标志。请填空。 #include main( ) { FILE * fp; char ch,fname [10]; printf("Input the name of file\n"); gets(fname); gets(fname); if((fp=[5])= =NULL) { printf("Cannot open\n"); exit(0); } printf("Enter data\n"); while((ch=getchar())!='#') fputc([6],fp); fclose(fp); } 三、上机操作题 1.改错题 下列给定程序中,函数fun的功能是:逐个比较a、b两个字符串对应位置中的字符,把ASCII值大或相等的字符依次存放到c数组中,形成一个新的字符串。例如:若a中的字符串为:aBCDeFgH,b中的字符串为:ABcd,则c中的字符串应为:aBcdeFgH.请改正程序中的错误,使它能得到正确结果,注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。 试题程序: #include #include void fun (char *p, char *q, char *c) { int k=1; while(*p! = *q) { if ( *p!< *q) c[k]= *q; else c[k]= *p; if(*p) p++; if(*q) q++; k++; } } main( ) { char a[10]="aBCDeFfH",b[10]="ABcd",c[80]={"\ 0"}; fun (a,b,c); printf("The string a:");puts (a); ptintf("The string b:");puts (b); printf("The result :");puts(c); 2.编程题 请编写函数fun,它的功能是:求出1到1000之内能被7或11整除、但不能同时被7和11整除的所有整数并将它们放在a所指的数组中,通过n返回这些数的个数。注意:部分源程序给出如下。请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。 试题程序: # include < conio.h> # include < stdio.h> void fun ( int *a, int *n) { } main( ) { int aa[1000],n,k; clrscr( ); fun (aa,&n); for (k=0;k if((k+1)%10= = 0) printf ("\n"); else printf("%5d",aa[k]); } 二级(C语言程序设计)样题参考答案 公共基础知识 一、选择题 (1)D (2)C (3)D (4)B 二、填空题 (1)[1]O(Nlog2 N) (2)[2]功能模型 (3)[3]软件外部功能 (4)[4]二维表 C语言程序设计 一、选择题 (1)A (2)D (3)B (4)A (5)C (6)C (7)C (8)D (9)D (10)C 二、填空题 (1)[1] (x>10&&x<100)//x<0 或(10或x<0//(x>10&&x<100) 或0>x//(10(并且括号有无都可以) (2)[2]GFEDCB (3)[3] 7 1 (4)[4]HOW how do you do (说明:HOW和how之间有无空格均可) (5)[5]fopen(fname,"w") (说明:"w"内以w开头的字符串均可) [6] ch
|