}
Main()
{intc[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,
(35)有以下程序
#include
intfun(chars[])
{intn=0;
while(*s<=‘9’&&*s>=‘0’){n=[0*n+*s-‘0’;s++;}
return(n);
}
main()
{chars[10]={“6”,“1”,“*”,“4”,“*”,“9”,“*”,‘0’,“*”}
printf(“%d﹨n”,fun(s));
}
程序的运行结果是
A)9B)61490C)61D)5
(36)当用户要求输入的字符串中含有空格时,应使用的输入函数是
A)scanf()B)getchar()C)getsD)getc()
(37)以下关于字符串的叙述中正确的是
A)C语言中有字符串类型的常量和变量
B)两个字符串中的字符个数相同时才能进行字符串大小的比较
C)可以用关系运算符对字符串的大小进行比较
D)空串一定比空格打头的字符串小
(38)有以下程序
#include
voidfun(char*t,char*s)
{while(*t!
=0)t++;
while{(*t++=*s++)!
=0};
}
min()
{charss[10]=“acc”,aa[10]=“bbxxyy”;
fun(ss,aa);printf(“%s,%s﹨n”,ss,aa);
}
程序的运行结果是
A)accxyy,bbxxyyB)axx,bbxxyy
C)accxxyy,bbxxyyD)accbbxxyy,bbxxyy
(39)有以下程序
#include
#include
voidfun(chars[][10],intn)
{chart;intij;
for(i=0;ifor(j=i+1;j/*比较字符串的首字符大小,并交换字符串的首字符*/
if(s[i][0]>s[j][0]){l=s[i][0];s[i][0];s[j][0]=t;}
}
main()
{charss[5][10]={“bcc”,“bbcc”,“xy”,“aaaacc”,“aabbc”};
Fun(ss,5);printf(“%s,%s﹨n”,ss[0],ss[4]);
}
程序的运行结果是
A)xy,aaaaccB)aaaacc,xyC)xcc,aabccD)acc,xabcc
(40)在一个C源程序文件中所定义的全局变量,其作用域为
A)所在文件的全部范围B)所在程序的全部范围
C)所在函数的全部范围D)由具体定义位置和extrn说明来决定范围
(41)有以下程序
#includc
inta=1;
intf(intc)
{staticinta=2;
c=c+1
return(a++)+c;
}
Main()
{inti,k=0;
for(i=0;i<2;i++{inta=3;k+=f(a);}
k+=a;
printf(“%d﹨n”,k);
}
程序的运行结果是
A)14B(15)C)16D)17
(42)有以下程序
#include
voidfun(intn,int*p)
{intf1,f2;
if(n=1||n=2)*p=1;
else
{fun(n-1,&f1);fun(n-2,&f2);
*p=f1+f2;
}
}
main()
{ints;
fun(3,&s);printf(“%d﹨n”);
}
程序的运行结果是
A)2B)3C)4D)5
(43)若程序中有宏定义行:
#defineN100则以下叙述中正确的是
A)宏定义行中定义了标识符N的值为整数100
B)在编译程序对C源程序进行预处理时用100替换标识符N
C)对C源程序进行编译时用100替换标识符N
D)在运行时用100替换标识符N
(44)以下关于typedef的途述错误的是
A)用typedef可以增加新类型
B)typedef是将已存在的类型用一个新的名字来代表
C)用typedef可以为各种类型说明一个新名,但不能用来为变量说明一个新名
D)用typedef为类型说明一个新名,通常可以增加程序的可读性
(45)有以下程序
#include
structtt
{intx;structtt*y;}*p;
Structtta[4]={20,a+1,15,a+2,30,a+3,17,a};
main()
{inti;
p=a;
for(i=1;i<=2,i++){printf(“%d,”,p->x);p=p->y;}
}
程序的运行结果是
A)20,30,B)30,17C15,30,D)20,15
(46)有以下程序
#include
#include
Typedefstructcharname[9];charsex;floatscore[2];}STU;
STUf(STUa)
{STUb={“zhao”,‘m’,85-0,90,0};inti;
Strcpy(a.name,b.name);
a.sex=b.sex;
for(i=0;i<2;i++)a.score[i]=b.score[i];
retuma;
}
main()
{STUc={“Qian”,‘f’,95.0,92.0}d;
d=f(c);printf(“%s,%c,%2.of,%2.of﹨n”,d.name,d.sex,d.score[0].d,score[1]);
}
程序的运行结果是
A)Qian,f,95,92B)Qian,m,85,90C)Zhao,m,85,90D)Zhao,f,95,92
(47)设有以下定义
Uniondata
{intdl;floatd2;}demo;
则下面叙述中错误的是
A)变量demo与成员d2所占的内存字节数相同
B)变量demo中各成员的地址相同
C)变量demo和各成员的地址相同
D)若给demo.d1赋99后,demo.d2中的值是99.0
(48)有以下程序
#include
Main()
{inta=1,b=2,c=3,x;
x=(a^b)&c;printf(“%d\n”,x);
}
程序的运行结果是
A)0B)1C)2D)3
(49)读取二进制文件的函数调用形式为:
fread(buffer,size,count,fp);其中buffer代表的是
A)一个文件指针,指向待读取的文件
B)一个整型变量,代表待读取的数据的字节数
C)一个内存块的首地址,代表读入数据存放的地址
D)一个内存块的字节数
(50)有以下程序
#include
Main()
{FILE*fp;inta[10]={1,2,3,0,0},i;
fp=fopen(“d2.dat”.”wb”)
fwrite(a,sizeof(int),5,fp)
fwrite(a,sizeof(int),5,fpj);
fclose(fp);
fp=fopen(“d2.dat”,”rb”);
fread(a,sizeof(int),10,fp);
fclose(fp);
for(i=0;i<10;i++)printf(“%d,”,a[i]);
}
程序的运行结果是
A)1,2,3,0,0,0,0,0,0,0B)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]至[20]序号的横线上,答在试卷上不得分。
(1)软件需求规格说明书应具有完整性、无歧义性、正确性、可验证性、可修改性等特性,其中最重要的是。
(2)在两种基本测试方法中,测试的原则之一是保证所测模块中每一个独立路径至少要执行一次。
(3)线性表的存储结构主要分为顺序存储结构和链式存储结构。
队列是一种特殊的线性表。
循环队列是队列的存储结构。
(4)对下列二叉树进行中序遍历的结果为。
(5)在E-R图中,矩形表示。
(6)执行以下程序时输入1234567,则输出结果是。
#include
Main()
{inta=1,b;
Scanf(“%2d%2d”,&a,&b);printf(“%d%d\n”,a,b)
}
(7)以下程序的功能是:
输出a、b、c三个变量中的最小值。
请填空。
#include
Main()
{inta,b,c,t1,t2;
Scanf(*%d%d%d”,&a,&b,&c);
t1=a
:
t2=c<1?
;
printf(“%d\n”,t2);
(8)以下程序的输出结果是。
#include
Main()
{intn=12345,d;
while(n!
=0){d=n%10;printf(“%d”,d);n/=10;}
}
(9)有以下程序段,且变量已正确定义和赋值
for(S=1.0,k=1;k<=n;k++)s=s+1.0/(k*(k+));
printf(“S=%f\n\n”,s);
请填空,使下面程序段的功能与之完全相同
S=1.0;k=1;
While(){s=s+1.0/(k*(k+1));;}
Printf(“s=%f\n\n”,s);
(10)以下程序的输出结果是。
#include
main()
{inti;
for(i=a;jprintf(“\n”);
}
(11)以下程序的输出结果是。
#include
#include
Char*fun(char*t)
{char*p=t;
retrun(p+strlen(t)/2);
}
main()
{char*str=”abcdefgh”;
str=fun(str);
puts(str);
}
(12)以下程序中函数f的功能是在数值x的n个数(假定n个数互不相同)中找出最大最小数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换。
请填空。
#include
voidf(intx[],intn)
{intp0,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;}
Elseif(x[m]}
t=x[p0];x[p0]=x[n-1];x[n-1]=1;
t=x[p1];x[p1]=;=t;
}
main()
{inta[10],u;
for(u=0;u<10;u++)scanf(*%d,&a[u]);
f(a,10);
for(u=0;u<10;u++)printf(“%d”,a[u]);
printf(“\n”);
}
(13)以下程序统计从终端输入的字符中大写字母的个数,num[0]中统计字母A的个数,num[1]中统计字母B的个数,其它依次类推。
用#号结束输入,请填空。
#include
#include
main()
{intnum[26]={0},i;charc;
while()!
=”#”)
if(isupper(c))num[c-‘A’]+=;
for(i=0;i<26;i++)
printf(*%c;%d\n”,i+’A’,num[i]);
}
(14)执行以下程序的输出结果是。
#include
main()
{inti,n[4]={1};
For(i=1;i<=3;i++)
{n[i]=n[i-1]*2+1;printf(”%d”,n[i]);}
}
(15)以下程序的输出结果是。
#include
#defineM5
#defineNM+M
main()
{intk;
K=N*N*5;printf(“%d\n”,k);
}
(16)函数min()的功能是:
在带头结点的单链表中查找数据域中值最小的结点。
请填空
#include
Structnode
{intiata;
Structnode*next;
};
Intmin(structnode*first)/*批针first为链表头指针*/
{structnod*p;intm;
P=first->next;m=p->data;p=p->next;
for(;p!
=NULL;p=)
if(