9月份全国计算机等级考试二级C语言上机题
库
第一套
在下列各题的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)假设线性表的长度为n,则在最坏情况下,冒泡排序需要的比较次数为
A)log2n B)n2 C)O(n1..5) D)n(n-1)/2
(8)在深度为5的满二叉树中,叶子结点的个数为
A)32 B)31 C)16 D)15
(9)数据库系统的核心是
A)数据库B)数据库管理系统
C)模拟模型D)软件工程
(10)一个关系中属性个数为1时,称此关系为
A)对应关系B)单一关系C)一元关系D)二元关系
(11)下面各选项中,均是C语言合法标识符的选项组是
A)33 we auto B)_23 me _3ew C)_43 3e_ else D)ER -DF 32
(12)可在C程序中用作用户标识符的一组标识符是
A)and B)Date
C)Hi D)case
_2007 y-m-d Dr.Tom Bigl
(13)以下对C语言函数的有关描述中,正确的是
A)在C语言中调用函数时,只能把实参的
值传给形参,形参的值不能传送给实参
B)C函数既可以嵌套定义又可以递归调用
C)函数必须有返回值,否则不能使用函数
D)函数必须有返回值,返回值类型不定
(14)若函数调用时的实参为变量时,以下关于
函数形参和实参的叙述中正确的是
A)函数的实参和其对应的形参共占同一
存储单元B)形参只是形式上的存在,不占
用具体存储单元
C)同名的实参和形参占同一存储单元
D)函数的形参和实参分别占用不同的存储单
元
(15)现有定义int a;double b;float c;char k;,
则表达式a/b+c-k值的类型为:
A)int B)double
C)float D)char
(16)以下关于long、int和short类型数据
占用内存大小的叙述中正确的是
A)均占4个字节B)根据数据的大小来
决定所占内存的字节数
C)由用户自己定义D)由C语言编译
系统决定
(17)有以下程序段
int j;float y;char name[50];
scanf("%2d%f%s",&j,&y,name);
当执行上述程序段,从键盘上输入55566
7777abc后,y的值为
A)55566.0 B)566.0
C)7777.0 D)566777.0
(18)若变量已正确定义,有以下程序段
i=0;
do printf("%d,",i);while(i++);
printf("%d\n",i);
其输出结果是
A)0,0 B)0,1 C)1,1 D)
程序进入无限循环
(19)下列程序的运行结果是
#include "stdio.h"
main()
{ int x=-9,y=5,z=8;
if(x if(y<0)z=0; else z+=1; printf("%d\n",z);} A)6 B)7 C)8 D)9 (20)若程序执行时的输入数据是"2473",则 下述程序的输出结果是 #include void main() { int cs; while((cs=getchar())!=; '\n') {switch(cs-'2') { case 0 case 1: putchar(cs+4); case 2: putchar(cs+4); break; case 3: putchar(cs+3); default: putchar(cs+2); } } } A)668977 B)668966 C)6677877 D)6688766 (21)以下程序的输出结果是 main() { int a,i;a=0; for(i=1;i<5;i++) { switch(i) { case 0: case 3:a+=2; case 1: case 2:a+=3; default:a+=5; } }printf("%d\n",a);} A)31 B)13 C)10 D)20 (22)现有如下程序段 #include "stdio.h" main() { int k[30]={12,324,45,6,768,98,21,34,453,456}; int count=0,i=0; while(k[i]) { if(k[i]%2==0||k[i]%5==0)count++; i++; } printf("%d,%d\n",count,i);} 则程序段的输出结果为 A)7,8 B)8,8 C)7,10 D)8,10 (23)若有以下程序 #include int a[]={2,4,6,8}; main() { int i; int *p=a; for(i=0;i<4;i++)a[i]=*p; printf("%d\n",a[2]);} 上面程序的输出结果是 A)6 B)8 C)4 D)2 (24)有以下程序 #include main() { int i,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′的ASCII码值是65,字符变 量cl的值是′A′,c2 的值是′D′。执行语句 printf("%d,%d",c1,c2-2);后,输出结果是 A)A,B B)A,68 C)65,66 D)65,68 (26)下列程序是用来判断数组中特定元素的位置所在的。 #include #include int fun(int *s, int t, int *k) { int i; *k=0; for(i=0;i if(s[*k] return s[*k]; } main() { int a[10]={ 876,675,896,101,301,401,980,431, 451,777},k; fun(a, 10, &k); printf("%d, %d\n",k,a[k]);} 如果输入如下整数:876 675 896 101 301 401 980 431 451 777 则输出结果为 A)7,431 B)6 C)980 D)6,980 (27)下面程序的文件名为t.exe,在DOS下输入的命令行参数为:t to meet me<回车> 则程序输出的结果是 #include "stdio.h" main(argc,argv) int argc;char *argv[]; { int i; printf("%d\n",argc);} A)3 B)4 C)2 D)以上答案都不正确 (28)有如下程序 int a[10]={1,2,3,4,5,6,7,8,9,10}; int *p=&a[3],b;b=p[5]; 则b的值是 A)5 B)6 C)9 D)8 (29)以下叙述中错误的是 A)改变函数形参的值,不会改变对应实参的值B)函数可以返回地址值 C)可以给指针变量赋一个整数作为地址值D)当在程序的开头包含头文件stdio.h 时,可以给指针变量赋NULL (30)下面程序的输出结果是 #include main() { int a[]={1,2,3,4,5,6,7,8,9,0},*p; p=a; printf("%d\n",*p+9);} A)0 B)1 C)10 D)9 (31)有下面程序段 #include "stdio.h" #include "string.h" main() { char a[3][20]={{"china"},{"isa"},{"bigcountry!"}}; char k[100]={0},*p=k; int i; for(i=0;i<3;i++) { p=strcat(p,a[i]);} i=strlen(p); printf("%d\n",i);} 则程序段的输出结果是 A)18 B)19 C)20 D)21 (32)若有定义: char *st= "how are you "; , 下列程序段中正确的是 A)char a[11], *p; strcpy(p=a+1,&st[4]); B)char a[11]; strcpy(++a, st); C)char a[11]; strcpy(a, st); D)char a[], *p; strcpy(p=&a[1],st+2); (33)有以下程序 #include int fun(char s[]) { int n=0; while(*s<=′9′&&*s>=′0′) {n=10*n+*s-′ 0′;s++;} return(n); } main() { char s[10]={′6′,′1′,′*′,′4′,′*′,′9′,′*′,′0′,′*′}; printf("%d\n",fun(s)); } 程序的运行结果是 A)9 B)61490 C)61 D)5 (34)设有定义:char p[]={′1′,′2′,′3′},*q=p;, 以下不能计算出一个char型数据所占字节数 的表达式是 A)sizeof(p) B)sizeof(char) C)sizeof(*q) D)sizeof(p[0]) (35)有以下函数 int aaa(char *s) { char *t=s; while(*t++); t--; return(t-s); } 以下关于aaa函数的功能的叙述正确的是 A)求字符串s的长度B)比较两个串 的大小C)将串s复制到串t D) 求字符串s所占字节数 (36)当用户要求输入的字符串中含有空格时, 应使用的输入函数是 A)scanf() B)getchar() C)gets() D)getc() (37)下列选项中错误的说明语句是 A)char a[]={′t′,′o′,′y′,′o′,′u′,′\0′}; B)char a[]={"toyou\0"}; C)char a[]="toyou\0"; D)char a[]=′toyou\0′; (38)以下程序的输出结果是 int f() { static int i=0; int s=1; s+=i; i++; return s; } main() { int i,a=0; for(i=0;i<5;i++)a+=f(); printf("%d\n",a);} A)20 B)24 C)25 D)15 (39)下列程序的输出结果是 #include "stdio.h" #define M(x,y) x%y main() { int a,m=12,n=100; a=M(n,m); printf("%d\n",a--);} A)2 B)3 C)4 D)5 (40)假定当前盘符下有两个如下文本文件: 文件名a1.txt a2.txt 内容123# 321# 则下面程序段执行后的结果为 #include "stdio.h" void fc(FILE *p) { char c; while((c=fgetc(p))!=′#′)putchar(c);} main() { FILE *fp; fp=fopen("a1.txt","r"); fc(fp); fclose(fp); fp=fopen("a2.txt","r"); fc(fp); fclose(fp); putchar('\n');} A)123321 B)123 C)321 D)以上答案都不正确 答案 1)D (2)D (3)D (4)A (5)B (6)C (7)D (8)C (9)B (10)C (11)B (12)A (13)A (14)D (15)B (16)D (17)B (18)B (19)D (20)A (21)A (22)D (23)D (24)B (25)C (26)D (27)B (28)C 29)C (30)C (31)B (32)A (33)C (34)A (35)A (36)C (37)D (38)D (39)C (40)A 第二套 在下列各题的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中每个元素距其最终位置不远,为节省时间,应采用的算法是 A)堆排序B)直接插入排序C)快速排序D)B)和C) (7)栈底至栈顶依次存放元素A、B、C、D,在第五个元素E入栈前,栈中元素可以出栈,则出栈序列可能是 A)ABCED B)DCBEA C)DBCEA D)CDABE (8)数据库设计包括两个方面的设计内容,它们是 A)概念设计和逻辑设计B)模式设计和内模式设计C)内模式设计和物理设计D)结构特性设计和行为特性设计 (9)关系表中的每一横行称为一个 A)元组B)字段C)属性D)码 (10)设有表示学生选课的三张表,学生S(学号,姓名,性别,年龄,身份证号),课程C(课号,课名),选课SC(学号,课号,成绩),则表SC的关键字(键或码)为 A)课号,成绩B)学号,成绩C)学号,课号D)学号,姓名,成绩 (11)以下不正确的叙述是 A)在C程序中,逗号运算符的优先级最低 B)在C程序中,APH和aph是两个不同的变量 C)若a和b类型相同,在计算了赋值表达式a=b后b中的值将放入a中,而b中的值不变 D)当从键盘输入数据时,对于整型变量只能输入整型数值,对于实型变量只能输入实型数值 (12)请选出可用作C语言用户标识符的是 A)void,define,WORD B)a3_b3,_123,IF C)FOR,--abc,Case D)2a,Do,Sizeof (13)以下选项中,不能作为合法常量的是 A)1.234e04 B)1.234e0.4 C)1.234e+4 D)1.234e0 (14)在C语言中,运算对象必须是整型数的运算符是 A)% B)\ C)%和\ D)** (15)若变量均已正确定义并赋值,以下合法的 C语言赋值语句是 A)x=y==5; B)x=n%2.5; C)x+n=i; D)x=5=4+1; (16)有以下程序段 char ch; int k; ch=′a′; k=12; printf("%c,%d,",ch,ch,k); printf("k=%d \n",k); 已知字符a的ASCII码值为97,则执行上述程 序段后输出结果是 A)因变量类型与格式描述符的类型不匹 配输出无定值B)输出项与格式描述符个数 不符,输出为零值或不定值 C)a,97,12k=12 D)a,97,k=12 (17)已知字母A的ASCII代码值为65,若变 量kk为char型,以下不能正确判断出kk中的 值为大写字母的表达式是 A)kk>=′A′&& kk<=′Z′ B)!(kk>=′A′||kk<=′Z′) C)(kk+32)>=′a′ &&(kk+32)<=′Z′ D)isalpha(kk)&&(kk<91) (18)当变量c的值不为2、4、6时,值也为" 真"的表达式是 A)(c==2)||(c==4)||(c==6) B)(c>=2&& c<=6)||(c!=3)||(c!=5) C)(c>=2&&c<=6)&&!(c%2) D)(c>=2&& c<=6)&&(c%2!=1) (19)若有条件表达式(exp)?a++:b--,则以 下表达式中能完全等价于表达式(exp)的是 A)(exp==0) B)(exp!=0) C)(exp==1) D)(exp!=1) (20)以下不正确的定义语句是 A)double x[5]={2.0,4.0,6.0,8.0,10.0}; B)int y[5]={0,1,3,5,7,9}; C)char c1[]={′1′,′2′,′ 3′,′4′,′5′}; D)char c2[]={′\x10′, ′xa′, ′\x8′}; (21)下列程序执行后的输出结果是 main() { int a[3][3], *p,i; p=&a[0][0]; for(i=1; i<9; i++)p[i]=i+1; printf("%d\n",a[1][2];) A)3 B)6 C)9 D)随 机数 (22)设有以下程序段 int x=0,s=0; while(!x!=0)s+=++x; printf("%d",s); 则 A)运行程序段后输出0 B)运行程序段 后输出1 C)程序段中的控制表达式是非法 的D)程序段执行无限次 (23)(23)下面程序段的运行结果是 char *s="abcde"; s+=2;printf("%d",s); A)cde B)字符′c′C)字符′c′ 的地址D)无确定的输出结果 (24)阅读下列程序,则执行后的结果为 #include "stdio.h" main() { int c[][4]={1,2,3,4,5,6,7,34,213,56,62,3,23,12,3 4,56}; printf("%x,%x\n",c[2][2],*(*(c+1)+1));} A)3e,6 B)62,5 C)56,5 D)3E,6 (25)下面判断正确的是 A)char *a="china";等价于char *a;*a="china"; B)char str[5]={"china"}; 等价于char str[]={"china"}; C)char *s="china";等价于char *s;s="china"; D)char c[4]="abc",d[4]="abc";等价于char c[4]=d[4]="abc"; (26)若有定义:int a[2][3];,以下选项中对a 数组元素正确引用的是 A)a[2][!1] B)a[2][3] C)a[0][3] D)a[1>2][!1] (27)有定义语句:char s[10];,若要从终端给 s输入5个字符,错误的输入语句是 A)gets(&s[0]); B)scanf("%s",s+1); C)gets(s); D)scanf("%s",s[1]); (28)有以下程序 #include #define N 5 #define M N+1 #define f(x) (x*M) main() { int i1,i2; i1=f(2); i2=f(1+1); printf("%d %d\n",i1,i2); } 程序的运行结果是 A)12 12 B)11 7 C)11 11 D)12 7 (29)若有以下说明和定义 union dt { int a; char b; double c;}data; 以下叙述中错误的是 A)data的每个成员起始地址都相同 B)变量data所占内存字节数与成员c所占字 节数相等 C)程序 段:data.a=5;printf("%f\n",data.c);输出结果 为5.000000 D)data可以作为函数的实参 (30)有以下程序 #include main() {FILE *fp;int k,n,a[6]={1,2,3,4,5,6}; fp=fopen("d2.dat","w"); fprintf(fp,"%d%d%d\n",a[0],a[1],a[2]); fprintf(fp,"%d%d%d\n",a[3],a[4],a[5]); fclose(fp); fp=fopen("d2.dat","r"); fscanf(fp,"%d%d",&k,&n);printf("%d%d\n ",k,n); fclose(fp); } 程序运行后的输出结果是 A)1 2 B)1 4 C)123 4 D)123 456 (31)若已定义 int a[]={0,1,2,3,4,5,6,7,8,9}, *p=a,i; 其中则对a数组元素不正确的引用是 A)a[p-a] B)*(&a[i]) C)p[i] D)a[10] (32)有以下程序 #include void fun(int *s,int n1,int n2) { int i,j,t; i=n1; j=n2; while(i main() { int a[10]={1,2,3,4,5,6,7,8,9,0},k; fun(a,0,3); fun(a,4,9); fun(a,0,9); for(k=0;k printf("\n"); } 程序的运行结果是 A)0987654321 B)4321098765 C)5678901234 D)0987651234 (33)阅读下列程序,当运行函数时,输入asd af aa z67,则输出为 #include #include #include int fun (char *str) { int i,j=0; for(i=0;str[i]!=′\0′;i++) if(str[i]!=′′)str[j++]=str[i]; str[j]= ′\0′; } main() { char str[81]; int n; printf("Input a string : "); gets(str); puts(str); fun(str); printf("%s\n",str); } A)asdafaaz67 B)asd af aa z67 C)asd D)z67 (34)有以下程序int fun(int n) {if(n==1)return 1; else return(n+fun(n-1)); } main() {int x; scanf("%d",&x); x=fun(x);printf("%d\n",x) } 执行程序时,给变量x输入10,程序的输出结果 是 A)55 B)54 C)65 D)45 (35)下面程序段中,输出*的个数是 char *s="\ta\018bc"; for(;*s!='\0';s++)printf("*"); A)9 B)5 C)6 D)7 (36)C语言结构体类型变量在程序运行期间 A)TC环境在内存中仅仅开辟一个存放结 构体变量地址的单元B)所有的成员一直 驻留在内存中 C)只有最开始的成员驻留在内存中 D)部分成员驻留在内存中 (37)已知函数的调用形式为 fread(buf,size,count,fp),参数buf的含义是 A)一个整型变量,代表要读入的数据项总 数B)一个文件指针,指向要读的文件 C)一个指针,指向要读入数据的存放地址 D)一个存储区,存放要读的数据项 (38)设有以下语句 char x=3,y=6,z; z=x^y<<2; 则z的二进制值是 A)00010100 B)00011011 C)00011100 D)00011000 (39)在C语言中,只有在使用时才占用内存 单元的变量,其存储类型是 A)auto和register B)extern 和register C)auto和static D)static和register (40)设有定义语句int ( *f)(int);,则以下 叙述正确的是 A)f是基类型为int的指针变量B)f 是指向函数的指针变量,该函数具有一个int类 型的形参 C)f是指向int类型一维数组的指针变量 D)f是函数名,该函数的返回值是基类型为int 类型的地址 答案 (1)C (2)C (3)C (4)D (5)C (6)B (7)B (8)A (9)A (10)C (11)D (12)B (13)B (14)A (15)A (16)D (17)B (18)B (19)B (20)B (21)B (22)B (23)C (24)A (25)C (26)D (27)D (28)B (29)D (30)D (31)D (32)C (33)A (34)A (35)C (36)B (37)C (38)B (39)A (40)B 第三套 在下列各题的A)、B)、C)、D)四个选项中, 只有一个选项是正确的。 (1)为了避免流程图在描述程序逻辑时的灵 活性,提出了用方框图来代替传统的程序流程 图,通常也把这种图称为 A)PAD图 B)N-S图C)结构图 D)数据流图 (2)结构化程序设计主要强调的是 A)程序的规模B)程序的效率C) 程序设计语言的先进性D)程序易 读性 (3)为了使模块尽可能独立,要求 A)模块的内聚程度要尽量高,且各模块 间的耦合程度要尽量强 B)模块的内聚程度要尽量高,且各模块 间的耦合程度要尽量弱 C)模块的内聚程度要尽量低,且各模块 间的耦合程度要尽量弱 D)模块的内聚程度要尽量低,且各模块间 的耦合程度要尽量强 (4)需求分析阶段的任务是确定 A)软件开发方法B)软件开发工具 C)软件开发费用D)软件系统功能 (5)算法的有穷性是指 A)算法程序的运行时间是有限的 B)算法程序所处理的数据量是有限的 C)算法程序的长度是有限的 D)算法只能被有限的用户使用 (6)对长度为n的线性表排序,在最坏情况下, 比较次数不是n(n-1)/2的排序方法是 A)快速排序B)冒泡排序C) 直接插入排序D)堆排序 (7)如果进栈序列为e1,e2,e3,e4,则可能的出 栈序列是 A)e3,e1,e4,e2 B)e2,e4,e3,e1 C)e3,e4,e1,e2 D) 任意顺序 (8)将E-R图转换到关系模式时,实体与联系 都可以表示成 A)属性B)关系C)键D)域 (9)有三个关系R、S和T如下: R B C D a 0 k1 b 1 n1 S B C D f 3 h2 a 0 k1 n 2 x1 T B C D a 0 k1 由关系R和S通过运算得到关系T,则所使用的 运算为 A)并B)自然连接C)笛卡尔积 D)交 (10)下列有关数据库的描述,正确的是 A)数据处理是将信息转化为数据的过程 B)数据的物理独立性是指当数据的逻辑结构改变时,数据的存储结构不变 C)关系中的每一列称为元组,一个元组就是一个字段 D)如果一个关系中的属性或属性组并非 该关系的关键字,但它是另一个关系的关 键字,则称其为本关系的外关键字(11)以下叙述中正确的是 A)用C程序实现的算法必须要有输入和输出操作 B)用C程序实现的算法可以没有输出但必须要有输入 C)用C程序实现的算法可以没有输入但必须要有输出 D)用C程序实现的算法可以既没有输入也没有输出 (12)下列可用于C语言用户标识符的一组是 A)void, define, WORD B)a3_3,_123,Car C)For, -abc, IF Case D)2a, DO, sizeof (13)以下选项中可作为C语言合法常量的是 A)-80 B)-080 C)-8e1.0 D)-80.0e (14)若有语句:char *line[5];,以下叙述中正确的是 A) 定义line是一个数组,每个数组元素是一个基类型为char为指针变量 B) 定义line是一个指针变量,该变量可以指向一个长度为5的字符型数组 C) 定义line是一个指针数组,语句中的*号称为间址运算符 D) 定义line是一个指向字符型函数的指针 (15)以下定义语句中正确的是 A)int a=b=0; B)char A=65+1,b=′b′; C)float a=1,*b=&a,*c=&b; D)double a=0 0;b=1.1; (16)有以下程序段 char ch; int k; ch=′a′; k=12; printf("%c,%d,",ch,ch,k); printf("k=%d \n",k); 已知字符a的ASCII码值为97,则执行上述程序段后输出结果是 A)因变量类型与格式描述符的类型不匹配输出无定值 B)输出项与格式描述符个数不符,输出为零值或不定值 C)a,97,12k=12 D)a,97,k=12 (17)有以下程序 main() { int i,s=1; for (i=1;i<50;i++) if(!(i%5)&&!(i%3)) s+=i; printf("%d\n",s);} 程序的输出结果是 A)409 B)277 C)1 D)91 (18)当变量c的值不为2、4、6时,值也为" 真"的表达式是 A)(c==2)||(c==4)||(c==6) B)(c>=2&& c<=6)||(c!=3)||(c!=5) C)(c>=2&&c<=6)&&!(c%2) D)(c>=2&& c<=6)&&(c%2!=1) (19)若变量已正确定义,有以下程序段 int a=3,b=5,c=7; if(a>b) a=b; c=a; if(c!=a) c=b; printf("%d,%d,%d\n",a,b,c); 其输出结果是 A)程序段有语法错B)3,5,3 C)3,5,5 D)3,5,7 (20)有以下程序 #include main() { int x=1,y=0,a=0,b=0; switch(x) { case 1: switch(y) { case 0:a++; break; case 1:b++; break; } case 2:a++; b++; break; case 3:a++; b++; } printf("a=%d,b=%d\n",a,b); } 程序的运行结果是 A)a=1,b=0 B)a=2,b=2 C)a=1,b=1 D)a=2,b=1 (21)下列程序的输出结果是 #include "stdio.h" main() { int i,a=0,b=0; for(i=1;i<10;i++) { if(i%2==0) {a++; continue;} b++;} printf("a=%d,b=%d",a,b); } A)a=4,b=4 B)a=4,b=5 C)a=5,b=4 D)a=5,b=5 (22)已知 #int t=0; while (t=1) {...} 则以下叙述正确的是 A)循环控制表达式的值为0 B)循环控制表达式的值为1 C)循环控制表达式不合法 D)以上说法都不对 (23)下面程序的输出结果是 main() { int a[10]={1,2,3,4,5,6,7,8,9,10},*p=a; printf("%d\n",*(p+2));} A)3 B)4 C)1 D)2 (24)以下错误的定义语句是 A)int x[][3]={{0},{1},{1,2,3}}; B)int x[4][3]={{1,2,3},{1,2,3},{1,2,3},{1,2,3}}; C)int x[4][]={{1,2,3},{1,2,3},{1,2,3},{1,2,3}}; D)int x[][3]={1,2,3,4}; (25)有以下程序 void ss(char *s,char t) { while(*s) { if(*s==t)*s=t-′a′+′A′; s++; } } main() { char str1[100]="abcddfefdbd",c=′d′; ss(str1,c); printf("%s\n",str1);} 程序运行后的输出结果是 A)ABCDDEFEDBD B)abcDDfefDbD C)abcAAfefAbA D)Abcddfefdbd (26)有如下程序 main() { char ch[2][5]={"6937","8254"},*p[2]; int i,j,s=0; for(i=0;i<2;i++)p[i]=ch[i]; for(i=0;i<2;i++) for(j=0;p[i][j]>′\0′;j+=2) s=10*s+p[i][j]-′0′; printf("%d\n",s);} 该程序的输出结果是 A)69825 B)63825 C)6385 D)693825 (27)有定义语句:char s[10];,若要从终端给 s输入5个字符,错误的输入语句是 A)gets(&s[0]); B)scanf("%s",s+1); C)gets(s); D)scanf("%s",s[1]); (28)以下叙述中错误的是 A)在程序中凡是以"#"开始的语句行都是 预处理命令行B)预处理命令行的最后不 能以分号表示结束C)#define MAX 是合法的宏定义命令行D)C程序 对预处理命令行的处理是在程序执行的过程 中进行的 (29)设有以下说明语句 typedef struct { int n; char ch[8]; } PER; 则下面叙述中正确的是 A)PER 是结构体变量名B)PER是结构 体类型名C)typedef struct 是结构体类 型D)struct 是结构体类型名 (30)以下叙述中错误的是 A)gets函数用于从终端读入字符串 B)getchar函数用于从磁盘文件读入字符 C)fputs函数用于把字符串输出到文件 D)fwrite函数用于以二进制形式输出数据到文件 (31)以下能正确定义一维数组的选项是 A)int a[5]={0,1,2,3,4,5}; B)char a[]={′0′,′1′,′2′,′3′,′4′,′5′,′\0′}; C)char a={′A′,′B′,′C′}; D)int a[5]="0123"; (32)有以下程序 #include main() { char p[]={′a′, ′b′, ′c′},q[10]={ ′a′, ′b′, ′c′}; printf("%d%d\n",strlen(p),strlen(q));} 以下叙述中正确的是 A) 在给p和q数组置初值时,系统会自动添加字符串结束符,故输出的长度都为3 B) 由于p数组中没有字符串结束符,长度不能确定,但q数组中字符串长度为3 C) 由于q数组中没有字符串结束符,长度不能确定,但p数组中字符串长度为3 D) 由于p和q数组中都没有字符串结束符,故长度都不能确定 (33)有以下程序 #include #include void fun(char *s[],int n) { char *t; int i,j; for(i=0;i for(j=i+1;j if(strlen(s[i])>strlen(s[j])) {t=s[i];s[i]:s[j];s[j]=t;} } main() { char *ss[]={"bcc","bbcc","xy","aaaacc","aabcc"}; fun(ss,5); printf("%s,%s\n",ss[0],ss[4]); } 程序的运行结果是 A)xy,aaaacc B)aaaacc,xy C)bcc,aabcc D)aabcc,bcc (34)有以下程序 #include int f(int x) { int y; if(x==0||x==1) return(3); y=x *x-f(x-2); return y; } main() { int z; z=f(3); printf("%d\n",z); } 程序的运行结果是 A)0 B)9 C)6 D)8 (35)下面程序段的运行结果是 char str[]="ABC",*p=str; printf("%d\n",*(p+3)); A)67 B)0 C)字符′C′的地址D) 字符′C′ (36)若有以下定义: struct link { int data; struct link *next; } a,b,c,*p,*q; 且变量a和b之间已有如下图所示的链表结构: 指针p指向变量a,q指向变量c。则能够把c 插入到a和b 之间并形成新的链表的语句组 是: A)a.next=c; c.next=b; B)p.next=q; q.next=p.next; C)p->next=&c; q->next=p->next; D)(*p).next=q; (*q).next=&b; (37)对于下述程序,在方式串分别采用"wt" 和"wb"运行时,两次生成的文件TEST的长度 分别是 #include void main() { FILE *fp=fopen("TEST",); fputc(′A′,fp);fputc(′\n′,fp); fputc(′B′,fp);fputc(′\n′,fp); fputc(′C′,fp); fclose(fp); } A)7字节、7字节B)7字节、5字节 C)5字节、7字节D)5字节、5字节 (38)变量a中的数据用二进制表示的形式是 01011101,变量b中的数据用二进制表示的形 式是11110000。若要求将a的高4位取反, 低4位不变,所要执行的运算是 A)a^b B)a|b C)a&b D)a<<4 (39)下面的程序段运行后,输出结果是 int i,j,x=0; static int a[8][8]; for(i=0;i<3;i++) for(j=0;j<3;j++) a[i][j]=2*i+j; for(i=0;i<8;i++) x+=a[i][j]; printf("%d",x); A)9 B)不确定值C)0 D)18 (40)下列程序执行后的输出结果是 void func(int *a,int b[]) { b[0]=*a+6; } main() { int a,b[5]; a=0; b[0]=3; func(&a,b); printf("%d\n",b[0]);} A)6 B)7 C)8 D)9 答案 (1)B (2)D (3)B (4)D (5)A (6)D (7)B (8)B (9)D (10)D 11)C (12)B (13)A (14)A (15)B (16)D (17)D (18)B (19)B (20)D (21)B (22)B (23)A (24)C (25)B (26)C (27)D (28)D (29)B (30)B (31)B (32)A (33)A (34)C (35)B (36)D (37)B (38)A (39)C (40)A 第四套 在下列各题的A)、B)、C)、D)四个选项中, 只有一个选项是正确的。 (1)软件是指A)程序B)程序和 文档C)算法加数据结构D)程 序、数据与相关文档的完整集合 (2)检查软件产品是否符合需求定义的过程 称为 A)确认测试B)集成测试C) 验证测试D)验收测试 (3)以下不属于对象的基本特点的是 A)分类性B)多态性C)继承性 D)封装性 (4)在设计程序时,应采纳的原则之一是 A)不限制goto语句的使用B)减少 或取消注解行C)程序越短越好D) 程序结构应有助于读者理解 (5)下列叙述中正确的是 A)程序执行的效率与数据的存储结构密 切相关B)程序执行的效率只取决于程序 的控制结构 C)程序执行的效率只取决于所处理的数 据量D)以上三种说法都不对(6)数据结 构中,与所使用的计算机无关的是数据的 A)存储结构B)物理结构 C)逻辑结构D)物理和存 储结构 (7)线性表的顺序存储结构和线性表的链式 存储结构分别是 A)顺序存取的存储结构、顺序存取的存储 结构B)随机存取的存储结构、顺序存取的 存储结构 C)随机存取的存储结构、随机存取的存储 结构D)任意存取的存储结构、任意存取 的存储结构 (8)树是结点的集合,它的根结点数目是 A)有且只有1 B)1或多于1 C)0 或1 D)至少2 (9)下列有关数据库的描述,正确的是 A)数据库是一个DBF文件B)数据库 是一个关系C)数据库是一个结构化的数 据集合D)数据库是一组文件 (10)数据库、数据库系统和数据库管理系统 之间的关系是 A)数据库包括数据库系统和数据库管理 系统B)数据库系统包括数据库和数据库 管理系统C)数据 库管理系统包括数据库和数据库系统D) 三者没有明显的包含关系 (11)以下4个选项中,不能看作一条语句的是 A); B)a=5,b=2.5,c=3.6; C)if(a<5); D)if(b!=5)x=2;y=6; (12)下面四个选项中,均是不合法的用户标识符的选项是 A)A P_0 do B)float la0_A C)b-a goto int D)_123 temp int (13)以下选项中不属于字符常量的是 A)′C′B)′′C′′C)′\xCC′D) ′\072′ (14)设变量已正确定义并赋值,以下正确的表达式是 A)x=y*5=x+z B)int(15.8%5) C)x=y+z+5,++y D)x=25%5.0 (15)若变量已正确定义并赋值,以下符合C 语言语法的表达式是 A)a:=b+1 B)a=b=c+2 C)int 18.5%3 D)a=a+7=c+b (16)以下程序的运行结果是 int k=0; void fun(int m) {m+=k;k+=m;printf("m=%d k=%d ",m,k++);} main() {int i=4; fun(i++); printf("i=%d k=%d\n",i,k); } A)m=4 k=5 i=5 k=5 B)m=4 k=4 i=5 k=5 C)m=4 k=4 i=4 k=5 D)m=4 k=5 i=4 k=5 (17)已有定义:char c;,程序前面已在命令行中包含ctype.h文件,不能用于判断c中的字符是否为大写字母的表达式是 A)isupper(c) B)′A′<=c<=′Z′C)′A′<=c&&c<=′Z′D)c<=(′z′-32)&&(′a′-32)<=c (18)设有: int a=1,b=2,c=3,d=4,m=2,n=2; 执行(m=a>b)&&(n=c>d)后,n的值是 A)1 B)2 C)3 D)4 (19)若变量已正确定义,有以下程序段int a=3,b=5,c=7; if(a>b) a=b; c=a; if(c!=a) c=b; printf("%d,%d,%d\n",a,b,c); 其输出结果是 A)程序段有语法错B)3,5,3 C)3,5,5 D)3,5,7 (20)若有定义:float x=1.5;int a=1,b=3,c=2;,则正确的switch语句是 A)switch(x) {case 1.0:printf("*\n"); case 2.0:printf("**\n");} B)switch((int)x); {case 1:printf("*\n"); case 2:printf("**\n");} C)switch(a+b) {case 1:printf("*\n"); case 2+1:printf("**\n");} D)switch(a+b) {case1:printf(**\n);} casec:printf(**\n);} (21)有以下程序 #include main0 { int y=9; for( ; y>0;y--) if(y%3==0) printf("%d",--y); } 程序的运行结果是 A)741 B)963 C)852 D)875421 (22)以下描述中正确的是 A)由于do-while循环中循环体语句只能 是一条可执行语句,所以循环体内不能使用复 合语句 B)do-while循环由do开始,用while结束, 在while(表达式)后面不能写分号 C)在do-while循环体中,是先执行一次循 环,再进行判断D)do-while循环中,根据 情况可以省略while (23)有以下程序 #include main() { int a[ ]={1,2,3,4},y, *p=&a[3]; --p; y= *p;printf("y=%d\n",y); } 程序的运行结果是 A)y=0 B)y=1 C)y=2 D)y=3 (24)以下数组定义中错误的是 A)int x[][3]={0}; B)int x[2][3]={{l,2},{3,4},{5,6}}; C)int x[][3]={{l,2,3},{4,5,6}}; D)int x[2][3]={l,2,3,4,5,6}; (25)下面说明不正确的是 A)char a[10]="china"; B)char a[10],*p=a;p="china" C)char *a;a="china" D)char a[10],*p;p=a="china" (26)若有定义:int a[2][3];,以下选项中对a 数组元素正确引用的是 A)a[2][!1] B)a[2][3] C)a[0][3] D)a[1>2][!1] (27)若要求从键盘读入含有空格字符的字符 串,应使用函数 A)getc() B)gets() C)getchar() D)scanf() (28)阅读下列程序段,则程序的输出结果为 #include "stdio.h" #define M(X,Y)(X)*(Y) #define N(X,Y)(X)/(Y) main() { int a=5,b=6,c=8,k; k=N(M(a,b),c); printf("%d\n",k); A)3 B)5 C)6 D)8 (29)在16位IBM-PC机上使用C语言,若有 如下定义 struct data { int i; char ch; double f; } b; 则结构变量b占用内存的字节数是 A)1 B)2 C)7 D)11 (30)有以下程序#include main() {FILE *fp; int i,a[6]={l,2,3,4,5,6}; fp=fopen("d3.dat","w+b"); fwrite(a,sizeof(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, (31)有以下程序 #include main() { int s[12]={1,2,3,4,4,3,2,1,1,1,2,3},c[5]={0},i; for(i=0;i<12;i++) c[s[i]]++; for(i=1;i<5;i++) printf("%d",c[i]); printf("\n"); } 程序的运行结果是 A)1 2 3 4 B)2 3 4 4 C)4 3 3 2 D)1 1 2 3 (32)有以下程序 #include void fun(int *a,int n)/*fun函数的功能是 将a所指数组元素从大到小排序*/ { int t,i,j; for(i=0;i for(j=i+1;j if(a[i] } main() { 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("%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, (33)下面程序的输出结果是 #include #include main() { char *p1="abc",*p2="ABC",str[50]= "xyz"; strcpy(str+2,strcat(p1,p2)); printf("%s\n",str);} A)xyzabcABC B)zabcABC C)xyabcABC D)yzabcABC (34)以下函数返回a所指数组中最小的值所在的下标值 fun(int *a, int n) { int i,j=0,p; p=j; for(i=j;i if(a[i] return(p);} 在横线处应填入的是 A)i=p B)a[p]=a[i] C)p=j D)p=i (35)下列程序的运行结果为 #include void abc(char*str) { int a,b; for(a=b=0;str[a]!='\0';a++) if(str[a]!='c') str[b++]=str[a]; str[b]='\0';} void main() { char str[]="abcdef"; abc(str); printf("str[]=%s",str); } A)str[]=abdef B)str[]=abcdef C)str[]=a D)str[]=ab (36)有以下程序 #include #include typedef struct{ char name[9]; char sex; float score[2]; }STU; void f(STU a) { STU b={"Zhao",′m′,85 0,90 0}; int i; strcpy(https://www.wendangku.net/doc/9a3699486.html,,https://www.wendangku.net/doc/9a3699486.html,); a.sex= b.sex; for(i=0;i<2;i++) a.score[i]=b.score[i]; } main() { STU c={"Qian",′f′,95.0,92.0}; f(c); printf("%s,%c,%2.0f,%2.0f\n",https://www.wendangku.net/doc/9a3699486.html,,c.sex,c.score[0],c.score[1]); } 程序的运行结果是 A)Qian,f,95,92 B)Qian,m,85,90 C)Zhao,f,95,92 D)Zhao,m,85,90 (37)有以下程序 #include main() { FILE *fp; int a[10]={1,2,3},i,n; fp=fopen("d1.dat","w"); for(i=0;i<3;i++) fprintf(fp,"%d",a[i]); fprintf(fp,"\n"); fclose(fp); fp=fopen("d1.dat","r"); fscanf(fp,"%d",&n); fclose(fp); printf("%d\n",n); } 程序的运行结果是 A)12300 B)123 C)1 D)321 (38)已知int a=1,b=3则a^b的值为 A)3 B)1 C)2 D)4 (39)阅读下列程序,则运行结果为 #include "stdio.h" fun() { static int x=5; x++; return x;} main() { int i,x; for(i=0;i<3;i++) x=fun(); printf("%d\n",x);} A)5 B)6 C)7 D)8 (40)有以下程序 #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 答案 (1)D (2)A (3)C (4)D (5)A (6)C (7)B (8)C (9)C (10)B (11)D (12)C (13)B (14)C (15)B (16)B (17)B (18)B (19)B (20)C (21)C (22)C (23)D (24)B (25)D (26)D (27)B (28)A (29)D (30)A (31)C (32)D (33)C (34)D (35)A (36)A (37)B (38)C (39)D (40)D 第五套 在下列各题的A)、B)、C)、D)四个选项中, 只有一个选项是正确的。 (1)算法的空间复杂度是指 A)算法程序的长度B)算法程序中 的指令条数C)算法程序所占的存储空间 D)执行算法需要的内存空间 (2)在结构化程序设计中,模块划分的原则是 A)各模块应包括尽量多的功能B)各 模块的规模应尽量大C)各模块之间的联 系应尽量紧密 D)模块内具有高内聚度、模块间具有低耦 合度 (3)下列叙述中,不属于测试的特征的是 A)测试的挑剔性B)完全测试的不可 能性C)测试的可靠性D)测试的经济 性 (4)下面关于对象概念的描述中,错误的是 A)对象就是C语言中的结构体变量 B)对象代表着正在创建的系统中的一个实体 C)对象是一个状态和操作(或方法)的封装 体D)对象之间的信息传递是通过消息进 行的 (5)下列关于队列的叙述中正确的是 A)在队列中只能插入数据B)在队列 中只能删除数据C)队列是先进先出的线 性表D)队列是先进后出的线性表 (6)已知二叉树后序遍历序列是dabec,中序 遍历序列是debac,它的前序遍历序列是 A)acbed B)decab C)deabc D)cedba (7)某二叉树中有n个度为2的结点,则该二 叉树中的叶子结点数为 A)n+1 B)n-1 C)2n D)n/2 (8)设有如下三个关系表 R S T A B C A B C m 1 3 m 1 3 n n 1 3 下列操作中正确的是 A) T=R∩S B) T=R∪S C) T=R×S D) T=R/S (9)下列叙述中,正确的是 A)用E-R图能够表示实体集间一对一的联 系、一对多的联系和多对多的联系B)用 E-R图只能表示实体集之间一对一的联系 C)用E-R图只能表示实体集之间一对多的联系 D)用E-R图表示的概念数据模型只能转换为关系数据模型 (10)下列有关数据库的描述,正确的是 A)数据处理是将信息转化为数据的过程 B)数据的物理独立性是指当数据的逻辑结构改变时,数据的存储结构不变 C)关系中的每一列称为元组,一个元组就是一个字段D)如果一个关系中的属性或属性组并非该关系的关键字,但它是另一个关系的关键字,则称其为本关系的外关键字(11)C语言规定,在一个源程序中,main函数的位置 A)必须在最开始B)必须在系统调用的库函数的后面C)可以任意D)必须在最后 (12)以下叙述中错误的是 A)计算机不能直接执行用C语言编写的源程序B)C程序经C编译程序编译后,生成后缀为.obj的文件是一个二进制文件 C)后缀为.obj的文件,经连接程序生成后缀为.exe的文件是一个二进制文件D)后缀为.obj和.exe的二进制文件都可以直接运行(13)下列选项可以正确表示字符型常量的是 A)′\r′B)"a" C)"\897" D)296 (14)以下叙述中正确的是 A)构成C程序的基本单位是函数B)可以在一个函数中定义另一个函数 C)main()函数必须放在其他函数之前 D)C函数定义的格式是K&R格式 (15)设变量均已正确定义,若要通过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<回车>20□Y<回车> D) 10X<回车> 20Y<回车> (16)若有说明:int *p,m=5,n;,以下正确的程序段是 A)p=&n;scanf("%d",&p); B)p=&n;scanf("%d",*p) C)scanf("%d",&n);*p=n; D)p=&n;*p=m; (17)在执行下述程序时,若从键盘输入6和8,则结果为 main() { int a,b,s; scanf("%d%d",&a,&b); s=a if(a s=b; s*=s; printf("%d",s); } A)36 B)64 C)48 D)以上都不对 (18)若执行下面的程序时,从键盘输入5和2,则输出结果是 main() { int a,b,k; scanf("%d,%d ",&a,&b); k=a; if(a else k=b%a; printf("%d\n",k);} A)5 B)3 C)2 D)0 (19)在C语言中,函数返回值的类型最终取 决于 A)函数定义时在函数首部所说明的函数 类型B)return语句中表达式值的类型 C)调用函数时主调函数所传递的实参类型 D)函数定义时形参的类型 (20)已知大写字母A的ASCII码是65,小写 字母a的ASCII码是97。以下不能将变量c 中的大写字母转换为对应小写字母的语句是 A)c=(c-′A′)%26+′a′B)c=c+32 C)c=c-′A′+′a′D)c=(′A′+c)%26-′a′ (21)以下选项中,当x为大于l的奇数时,值为 0的表达式是 A)x%2==1 B)x/2 C)x%2!=0 D)x%2==0 (22)有以下程序 main() {int k=5,n=0; do {switch(k) {case 1: case 3:n+=1;k--;break; default:n=0;k--; case 2: case 4:n+=2;k--;break; } printf("%d",n); }while(k>0 && n<5); } 程序运行后的输出结果是 A)235 B)0235 C)02356 D)2356 (23)有如下程序 main() { int n=9; while(n>6){n--; printf("%d",n);} } 该程序的输出结果是 A)987 B)876 C)8765 D)9876 (24)有以下程序 #include main() { int c; while((c=getchar())!=′\n) { switch(c-′2′) { case 0: case 1:putchar(c+4); case 2:putchar(c+4);break; case 3:putchar(c+3); case 4:putchar(c+3);break; } } printf("\n")} 从第一列开始输入以下数据 车符。 2743 程序的输出结果是 A)66877 B)668966 C)6677877 D)6688766 (25)有以下程序 main() { int x=0,y=0,i; for (i=1;;++i) { if (i%2==0) {x++;continue;} if (i%5==0) {y++;break;} } printf (" %d,%d",x,y); } 程序的输出结果是 A)2,1 B)2,2 C)2,5 D)5,2 (26)有以下程序 main() {int a[4][4]={{l,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][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][i]); } 程序运行后的输出结果是 A)1,6,5,7, B)8,7,3,1, C)4,7,5,2, D)1,6,2,1, (27)有以下程序 int f(int n) { if(n==1)return 1; else return f(n-1)+1;} main() { int i,j=0; for(i=1;i<3;i++)j+=f(i); printf("%d\n",j);} 程序运行后的输出结果是 A)4 B)3 C)2 D)1 (28)当运行以下程序时,从键盘输入 AhaMA(空格)Aha 结果是 #include main() { char s[80],c=′a′; int i=0; scanf("%s",s); while(s[i]!=′ { if(s[i]==c)s[i]-32; else if(s[i]==c-32)s[i]=s[i]+32; i++; } puts(s); } A)ahaMa B)AbAMa C)AhAMa[空格]ahA D)ahAMa[空 格]ahA (29)下面程序输出的结果是 main() { int i; int a[3][3]={1,2,3,4,5,6,7,8,9}; for(i=0;i<3;i++) printf("%d ",a[2-i][i]); } A)1 5 9 B)7 5 3 C)3 5 7 D)5 9 1 (30)现有如下程序段 #include "stdio.h" main() { int a[5][6]={23,3,65,21,6,78,28,5,67,25,435,76, 8,22,45,7,8,34,6,78,32,4,5,67,4,21,1}; int i=0,j=5; printf("%d\n",*(&a[0][0]+2*i+j-2));} 则程序的输出结果为 A)21 B)78 C)23 D)28 (31)请选出正确的程序段 A)int *p; scanf("%d",p); … B)int *s, k; *s=100; … C)int *s, k; char *p, c; s=&k; p=&c; *p=′a′; … D)int *s, k; char *p, e; s=&k; p=&c; s=p; *s=1; … (32)下面程序段的运行结果是 char a[]="lanuage",*p; p=a; while(*p!=′u′){printf("%c",*p-32);p++;} A)LANGUAGE B)language C)LAN D)langUAGE (33)以下程序的输出结果是 #include int a[3][3]={1,2,3,4,5,6,7,8,9,},*p; main() { p=(int*)malloc(sizeof(int)); f(p,a); printf("%d\n",*p); free(p); } f(int *s, int p[][3]) { *s=p[1][1];} A)1 B)4 C)7 D)5 (34)有以下程序 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[i]); } 程序运行后的输出结果是 A)2,2,3,4,5, B)6,2,3,4,5, C)1,2,3,4,5, D) 2,3,4,5,6, (35)以下合法的字符型常量是 A)′\x13′B) ′\081′ C) ′65′D)"\n" (36)有以下语句,则对a数组元素的引用不正 确的是 int a[10]={0,1,2,3,4,5,6,7,8,9},*p=a; A)a[p-a] B)*(&a[i]) C)p[i] D)*(*(a+i)) (37)有以下程序 # 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 (38)在C语言中,变量的隐含存储类别是 A)auto B)static C)extern D)无存储类别 (39)以下程序的输出结果是 main() { int c=35; printf("%d\n",c&c);} A)0 B)70 C)35 D)1 (40)有以下程序 #include main() { FILE *fp; int i=20,j=30,k,n; fp=fopen("d1.dat","w"); fprintf(fp,"%d\n",i);fprintf(fp,"%d\n",j); fclose(fp); fp=fopen("d1.dat","r"); fscanf(fp,"%d%d",&k,&n); printf("%d %d\n",k,n); fclose(fp); } 程序运行后的输出结果是 A)20 30 B)20 50 C)30 50 D)30 20 选择题 (1)D (2)D (3)C (4)A (5)C (6)D (7)A (8)C (9)A (10)D (11)C (12)D (13)A (14)A (15)D (16)D (17)B (19)A (20)D (21)D (22)A (23)B (24)A (25)A (26)A (27)B (28)A (29)B (30)A (31)C (32)C (33)D (34)B (35)A (36)D (37)B (38)A (39)C (40)A 第六套 在下列各题的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)对长度为n的线性表排序,在最坏情况下, 比较次数不是n(n-1)/2的排序方法是 A)快速排序B)冒泡排 序C)直接插入排序D)堆排序 (7)下列关于栈的叙述正确的是 A)栈按"先进先出"组织数据B) 栈按"先进后出"组织数据C)只能在栈底 插入数据D)不能删除数据 (8)在数据库设计中,将E-R图转换成关系数 据模型的过程属于 A)需求分析阶段B)概念设计 阶段C)逻辑设计阶段D)物理 设计阶段 (9)有三个关系R、S和T如下: R B C D a 0 k1 b 1 n1 S B C D f 3 h2 a 0 k1 n 2 x1 T B C D a 0 k1 由关系R和S通过运算得到关系T,则所使用的运算为A)并B)自然连接C)笛卡尔积D)交 (10)设有表示学生选课的三张表,学生S(学号,姓名,性别,年龄,身份证号),课程C(课号,课名),选课SC(学号,课号,成绩),则表SC的关键字(键或码)为A)课号,成绩B)学号,成绩C)学号,课号D)学号,姓名,成绩 (11)以下叙述中正确的是 A)C程序中的注释只能出现在程序的开始位置和语句的后面B)C程序书写格式严格,要求一行内只能写一个语句 C)C程序书写格式自由,一个语句可以写在多行上 D)用C语言编写的程序只能放在一个程序文件中 (12)以下选项中不合法的标识符是A)print B)FOR C)&a D)_00 (13)以下选项中不属于字符常量的是 A)′C′B)"C" C)′\xCC′D) ′\072′ (14)设变量已正确定义并赋值,以下正确的表达式是 A)x=y*5=x+z B)int(15.8%5) C)x=y+z+5,++y D)x=25%5.0 (15)以下定义语句中正确的是 A)int a=b=0; B)char A=65+1,b=′b′; C)float a=1, *b=&a, *c=&b; D)double a=0.0;b=1.1; (16)有以下程序段 char ch; int k; ch=′a′; k=12; printf("%c,%d,",ch,ch,k); printf("k=%d\n",k); 已知字符a的ASCII码值为97,则执行上述程序段后输出结果是 A)因变量类型与格式描述符的类型不匹配输出无定值B)输出项与格式描述符个数不符,输出为零值或不定值 C)a,97,12k=12 D)a,97,k=12 (17)已知字母A的ASCII码值为65,若变量kk为char型,以下不能正确判断出kk中的值为大写字母的表达式是 A)kk>=′A′&& kk<=′Z′B)!(kk>=′A′||kk<=′Z′) C)(kk+32)>=′a′&&(kk+32)<=′Z′D)isalpha(kk)&&(kk<91) (18)当变量c的值不为2、4、6时,值也为"真"的表达式是 A)(c==2)||(c==4)||(c==6) B)(c>=2&& c<=6)||(c!=3)||(c!=5) C)(c>=2&&c<=6)&&!(c%2) D)(c>=2&& c<=6)&&(c%2!=1) (19)若变量已正确定义,有以下程序段 int a=3,b=5,c=7; if(a>b) a=b; c=a; if(c!=a) c=b; printf("%d,%d,%d\n",a,b,c); 其输出结果是 A)程序段有语法错B)3,5,3 C)3,5,5 D)3,5,7 (20)有以下程序 #include main() { int x=1,y=0,a=0,b=0; switch(x) { case 1: switch(y) { case 0:a++; break; case 1: b++; break; } case 2:a++; b++; break; case 3:a++; b++; } printf("a=%d,b=%d\n",a,b); } 程序的运行结果是 A)a=1,b=0 B)a=2,b=2 C)a=1,b=1 D)a=2,b=1 (21)有以下程序 #include main() { int x=8; for( ; x>0; x--) { if(x%3) {printf("%d,",x--); continue;} printf("%d,",--x); } } 程序的运行结果是 A)7,4,2, B)8,7,5,2, C)9,7,6,4, D)8,5,4,2, (22)以下不构成无限循环的语句或语句组是 A) n=0; do{++n;}while(n<=0);B) n=0; while(1){n++;} C) n=10; while(n);{n--;} D) for(n=0,i=1; ;i++)n+=i; (23)有以下程序 #include main() { int a[ ]={1,2,3,4},y, *p=&a[3]; --P; y= *p;printf("y=%d\n",y); } 程序的运行结果是 A)y=0 B)y=1 C)y=2 D)y=3 (24)以下错误的定义语句是 A)int x[][3]={{0},{1},{1,2,3}}; B)int x[4][3]={{1,2,3},{1,2,3},{1,2,3},{1,2,3}}; C)int x[4][]={{1,2,3},{1,2,3},{1,2,3},{1,2,3}}; D)int x[][3]={1,2,3,4}; (25)设有如下程序段 char s[20]="Beijing", *p; p=s; 则执行p=s;语句后,以下叙述正确的是 A)可以用*p表示s[0] B)s数组 中元素的个数和p所指字符串长度相等 C)s和p都是指针变量D)数组 s中的内容和指针变量p中的内容相同 (26)若有定义:int a[2][3];,以下选项中对a 数组元素正确引用的是 A)a[2][!1] B)a[2][3] C)a[0][3] D)a[1>2][!1] (27)有定义语句:char s[10];,若要从终端给 s输入5个字符,错误的输入语句是 A)gets(&s[0]); B)scanf("%s",s+1); C)gets(s); D)scanf("%s",s[1]); (28)以下叙述中错误的是 A)在程序中凡是以"#"开始的语句行都是 预处理命令行B)预处理命令行的最后不 能以分号表示结束C)#define MAX是合 法的宏定义命令行D)C程序对预处理命 令行的处理是在程序执行的过程中进行的 (29)以下结构体类型说明和变量定义中正确 的是 A)tupedef strct {int n; char c;}REC; REC t1,t2; B)tupedef strct {int n; char c;}; REC t1,t2; C)tupedef strct REC; {int n=0; char c='A';}t1,t2; D)strct {int n; char c;}REC; REC t1,t2; (30)以下叙述中错误的是 A)gets函数用于从终端读入字符串 B)getchar函数用于从磁盘文件读入字符 C)fputs函数用于把字符串输出到文件 D)fwrite函数用于以二进制形式输出数据到文 件 (31)有以下程序 #include main() { int s[12]={1,2,3,4,4,3,2,1,1,1,2,3},c[5]={0},i; for(i=0;i<12;i++) c[s[i]]++; for(i=1;i<5;i++) printf("%d",c[i]); printf("\n"); } 程序的运行结果是 A)1 2 3 4 B)2 3 4 4 C)4 3 3 2 D)1 1 2 3 (32)有以下程序 #include void fun(int *s,int n1,int n2) { int i,j,t; i=n1; j=n2; while(i main() { int a[10]={1,2,3,4,5,6,7,8,9,0},k; fun(a,0,3); fun(a,4,9); fun(a,0,9); for(k=0;k printf("\n"); } 程序的运行结果是 A)0987654321 B)4321098765 C)5678901234 D)0987651234 (33)有以下程序 #include #include void fun(char *s[],int n) { char *t; int i,j; for(i=0;i for(j=i+1;j if(strlen(s[i])>strlen(s[j])) {t=s[i];s[i]:s[j];s[j]=t;} } main() { char *ss[]={"bcc","bbcc","xy","aaaacc","aabcc"}; fun(ss,5); printf("%s,%s\n",ss[0],ss[4]); } 程序的运行结果是 A)xy,aaaacc B)aaaacc,xy C)bcc,aabcc D)aabcc,bcc (34)有以下程序 #include int f(int x) { int y; if(x==0||x==1) return(3); y=x*x-f(x-2); return y; } main() { int z; z=f(3); printf("%d\n",z); } 程序的运行结果是 A)0 B)9 C)6 D)8 (35)有以下程序 #include void fun(char *a,char *b) { while(*a==′*′)a++; while( *b=*a){b++;a++;} } main() { char *s="*****a*b****",t[80]; fun(s,t); puts(t); } 程序的运行结果是 A)*****a*b B)a*b C)a*b**** D)ab (36)有以下程序 #include #include typedef struct{ char name[9]; char sex; float score[2]; }STU; void f(STU a) { STU b={"Zhao",′m′,85.0,90.0}; int i; strcpy(https://www.wendangku.net/doc/9a3699486.html,,https://www.wendangku.net/doc/9a3699486.html,); a.sex= b.sex; for(i=0;i<2;i++) a.score[i]=b.score[i]; } main() { STU c={"Qian",′f′,95.0,92.0}; f(c); printf("%s,%c,%2.0f,%2.0f\n", https://www.wendangku.net/doc/9a3699486.html,,c.sex,c.score[0],c.score[1]); } 程序的运行结果是 A)Qian,f,95,92 B)Qian,m,85,90 C)Zhao,f,95,92 D)Zhao,m,85,90 (37)有以下程序 #include main() { FILE *fp; int a[10]={1,2,3},i,n; fp=fopen("d1.dat","w"); for(i=0;i<3;i++) fprintf(fp,"%d",a[i]); fprintf(fp,"\n"); fclose(fp); fp=fopen("d1.dat","r"); fscanf(fp,"%d",&n); fclose(fp); printf("%d\n",n); } 程序的运行结果是 A)12300 B)123 C)1 D)321 (38)变量a中的数据用二进制表示的形式是 01011101,变量b中的数据用二进制表示的形 式是11110000。若要求将a的高4位取反, 低4位不变,所要执行的运算是 A)a^b B)a|b C)a&b D)a<<4 (39)在C语言中,只有在使用时才占用内存 单元的变量,其存储类型是 A)auto和register B)extern 和register C)auto和static D)static和register (40)设有定义语句int ( *f)(int);,则以下 叙述正确的是 A)f是基类型为int的指针变量B)f是 指向函数的指针变量,该函数具有一个int类型 的形参 C)f是指向int类型一维数组的指针变量 D)f是函数名,该函数的返回值是基类型为int 类型的地址 选择题 (1)C (2)A (3)B (4)B (5)A (6)D (7)B (8)C (9)D (10)C (11)C (12)C (13)B (14)C (15)B (16)D (17)B (18)B (19)B (20)D (21)D (22)A (23)D (24)C (25)A (26)D (27)D (28)D (29)A (30)B (31)C (32)C (33)A (34)C (35)C (36)A (37)B (38)A (39)A (40)B 上机题库 第一套 1.程序填空 程序通过定义学生结构体数组,存储了若干个学生的学号、姓名和三门课的成绩。函数fun 的功能是将存放学生数据的结构体数组,按照姓名的字典序(从小到大排序)。请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 第一处struct student t; 第二处for(i=0;i 第三处if(strcmp(a[i].name,a[j].name)>0) 2程序修改 给定程序MODI1.C中函数fun的功能是:在p所指字符串中找出ASCII码值最大的字符,将其放在第一个位置上;并将该字符前的原字符向上顺序移动。 /**found**/ q=p+i; /**found**/ while(q>p) 3程序设计 学生的记录由学号和成绩组成,N名学生的数据已在主函数中放入结构体数组s中,请编写了函数fun,它的功能是:把指定分数范围内的学生数据放在b所指的数组中,分数范围内的学生人数由函数值返回。 int fun(STREC *a,STREC *b,int l,int h) {int i,j=0; for(i=0;i if((a[i].s>=1&&a[i].s<=h) b[j++]=a[i]; return j; } 第二套 1.程序填空 给定程序中已建立一个带有头结点的单向链表,链表中的各结点按数据域递增有序连接。函数fun的功能是:删除链表中数据域值相同的结点,使之只保留一个。 第一处free(q); 第二处q=p->next; 第三处q=q->next; 2. 程序修改 给定程序MODI1.C中函数fun的功能是:用选择法对数组中的n各元素按从小到大的顺序进行排序。 /**found**/ p=j; /**found**/ p=i; 3. 程序设计 请编写一个fun函数,它的功能是:求出1到m之间(含m)能被7或11整除的所有整数放在数组a中,通过n返回这些数的个数。void fun(int m,int *a,int *n) { int i; *n=0; for(i=7;i<=m;i++) if((i%7==0)||(i%11==0)) a[(*n)++]=i; } 第三套 1. 程序填空 函数fun的功能是:逆置数组元素是的值。例 如:若a所指数组中的数据依次为:1、2、3、 4、5、6、7、8、9,则逆置后依次为:9、8、 7、6、5、4、3、2、1。形参n给出数组中数 组中数据的个数。 第一处for(i=0;i 第二处a[i]=a[n-1-i]; 第三处a[n-i-1]=t; 2程序修改 给定程序MODI1.C中函数fun的功能是:将 一个由八进制数字字符串组成的字符串转换 为与其面值相等的十进制整数。规定输入的字 符串最多只能包含5位八进制数字字符。 /**found**/ n=*p-‘0’; /**found**/ n=n*8+*p-‘0’; 3. 程序设计 学生的记录由学号和成绩组成,N名学生的数 据已在主函数中放入结构体数组s中,请编写 了函数fun,它的功能是:函数返回指定学号 的学生数据,指定的学生号在主函数中输入, 若没有找到指定学号,在结构体变量中给学号 置空串,给成绩置-1,作为函数值返回。(用 于字符串比较的函数是strcmp)。 STREC fun(STREC*a,char *b) { STREC c; Int i; c.num[0]=’\0’; c.s=-1; for(i=0;i if(strcmp(a[i].num,b)==0) {strcpy(c.num,a[i].num); c.s=a[i].s;break;} return c; } 第四套 1.程序填空 给定程序中,函数fun的功能是:在带有头结 点的单向链表中,查找数据域中值为ch的结 点。找到后通过函数值返回该结点在链表中所 处的顺序号:若不存在值为ch的结点,函数 值返回0. 第一处while(p!=0) 第二处if(p->data==ch)return n; 第三处k=fun(head,ch); 2. 程序修改 给定程序MODI1.C中函数fun的功能是:删 除p所指字符串的所有空白字符(包括制表符、 回车符及换行符)。输入字符串时用‘#’结束 输入。 /**found**/ for(i=0,t=0;p[i];i++) /**found**/ c[t]=’\0’; 3. 程序设计 请编写一个函数fun,将ss所指字符串中所有 下标为奇数位置上的字母转换为大写(若该位 置上不是字母,则不转换)。 void fun(char *ss) { int i; for(i=1;i {if(ss[i]>=’a’&&ss[i]<=’z’) ss[i]-=32; } } 第五套 1. 程序填空 给定程序中,函数fun的功能是:计算下式前 n项的和作为函数值返回。例如:当形参n的 值为10 的时,函数返回:9.6125588。 第一处s=0; 第二处for(i=1;i<=n;i++) 第三处s=s+(2.0*i-1)*(2.0*i+1)/(t*t); 2. 程序修改 给定程序MODI1.C中函数fun的功能是:统 计substr所指字符串在str所指字符串中出现 伯次数。 /**found**/ for(i=0;str[i];i++) /**found**/ if(substr[k+1]==’\0’) 3. 程序设计 请编写一个函数fun,它的功能是:根据以下 公式求JI的值(要求满足精度0.0005,即某 项小于0.0005时停止送代):程序运行后,如 果输入精度为0.0005,则程序输出为3.14…。 double fun(double eps) { double s=1,t=1./3; int n=1; while(t>=eps) {s+=t;n++;t=t*n/(2.0*n+1) ;} return(s*2.0); } 第六套 1. 程序填空 给定程序中,函数fun的功能是:将形参s所 指定字符串中所有的字母字符顺序前移,其他 字母顺序后移,处理后字符串的首地址作为函 数值返回。 第一处t[j]=s[i];j++; 第二处for(i=0;i t[j+i]=p[i]; 第三处t[j+k]=0; 2. 程序修改 给定程序MODI1.C中函数fun的功能是:将s所指字符串中最后一次出现的与t1所指字符串相同的子串替换成t2所指定字符串,所形成的新串放在w所指的数组中。在此处,要求t1和t2所指字符串的长度相同。 /**found**/ while(*w) /**found**/ if(*r==*p) 3. 程序设计 函数fun的功能是:将s所指字符串中ASCII 值为奇数的字符删除,串中剩余字符形成一个新串放在t所指定的数组中。 void fun(char *s,char t[]) { int i,j=0; for(i=0;i if(s[i]%2==0)t[j++]=s[i]; t[j]=0; } 第七套 1.程序填空 程序通过定义学生结构体变量,存储了学生的学号、姓名和三门课的成绩。函数fun的功能是将形参a所指结构体变量s中的数据进行修改,并把a中地址作为函数值返回主函数,在主函数中输出修改后的数据。 第一处struct student * fun(struct student*a) 第二处for(i=0;i<3;i++) a->score[i]+=1; 第三处return a; 2. 程序修改 给定程序MODI1.C中函数fun的功能是:从N个字符串中找出最长的那个串,并将其地址作为函数值返回。各字符串在主函数中输入,并放在一个字符串数组中。 /**found**/ char *fun(char (*sq)[M]) /**found**/ return sp; 3. 程序设计 函数fun的功能是:将a、b中的两位正整数合并形成一个新的整数放在c中。合并的方式是:将a中的十位和个位依次放在变量c的百位和个位上,b中的十位和个位数依次放在变量c的十位和千位上。 #include void fun(int a,int b,long *c) { *c=(b%10)*1000+(a/10)*100+(b/10)*10 +a%10; } 第八套1. 程序填空 函数fun的功能是:将形参观者工所指数组中 的前半部分元素中的值和后半部分元素中的 值对换。形参n中存放数组中数据的个数,若 n为奇书,则中间元素不动。 第一处p=(n%2==0)?n/2:n/2+1; 第二处a[i]=a[p+i]; 第三处a[p+i]=t; 2. 程序修改 给定程序MODI1.C中函数fun的功能是:把 主函数中输入的三个数,最大的放在a中,最 小的放在c中,中间的放在b中。 /**found**/ float k; /**found**/ if(*a<*c) 3. 程序设计 学生的记录由学号和成绩组成,N名 学生的数据已在主函数中放入结构体数组s 中,请编写了函数fun,它的功能是:把分数 最高的学生数据放在b所指的数组中,注意: 分数最高的学生可能不止一个,函数返回分数 最高的学生的人数。 int fun(STREC *a,STREC *b) { int i,max=a[0].s,n=0;