C语言课后习题答案第八章Word文档格式.docx
《C语言课后习题答案第八章Word文档格式.docx》由会员分享,可在线阅读,更多相关《C语言课后习题答案第八章Word文档格式.docx(14页珍藏版)》请在冰豆网上搜索。
![C语言课后习题答案第八章Word文档格式.docx](https://file1.bdocx.com/fileroot1/2022-10/17/ab1a631e-23ea-423c-a987-1aa297cfbc88/ab1a631e-23ea-423c-a987-1aa297cfbc881.gif)
在C语言中A)实参和与其对应的形参各占用独立的存储单元
B)实参和与其对应的形参共占用一个存储单元
C)只有当实参和与其对应的形参同名时才共占用存储单元
D)形参是虚拟的,不占用存储单元
4.若调用一个函数,且此函数中没有return语句,则正确的说法是D__。
该函数A)没有返回值
B)返回若干个系统默认值
C)能返回一个用户所希望的函数值
D)返回一个不确定的值(重要)
5.以下不正确的说法是B__。
C语言规定A)实参可以是常量、变量或表达式
B)形参可以是常量、变量或表达式
C)实参可以为任意类型
D)形参应与其对应的实参类型一致
6.C语言规定,简单变量做实参时,它和对应形参之间的数据传递方式是B__。
A)地址传递
B)单向值传递
C)由实参传给形参,再由形参传回给实参
D)由用户指定传递方式
7.以下程序有语法性错误,有关错误原因的正确说法是C__。
main()
{
intG=5,k;
voidPrt_char();
……
k=Prt_char(G);
A)语句voidprt_char();
有错,它是函数调用语句,不能用void说明
B)变量名不能使用大写字母
C)函数说明和函数调用语句之间有矛盾
D)函数名不能使用下划线
8.C语言允许函数值类型缺省定义,此时该函数值隐含的类型是B__。
A)float型
B)int型
C)long型
D)double型
9.C语言规定,函数返回值的类型是由D__。
A)return语句中的表达式类型所决定
B)调用该函数时的主调函数类型所决定
C)调用该函数时系统临时决定
D)在定义该函数时所指定的函数类型所决定
10.下面函数调用语句含有实参的个数为B__。
func((exp1,exp2),(exp3,exp4,exp5));
A)1B)2C)4D)5(重要)
11.以下程序的功能是计算函数F(x,y,z)=(x+y)/(x-y)+(z+y)/(z-y)的值,请选择填空。
#include<
stdio.h>
#include<
math.h>
main()
floatx,y,z,sum;
scanf(“%f%f%f”,&
x,&
y,&
z);
sum=f(【1】__B__)+f(【2】__C__);
printf(“sum=%f\n”,sum);
floatf(floata,floatb)
floatvalue;
value=a/b;
return(value);
【1】A)x-y,x+yB)x+y,x-yC)z+y,z-yD)z-y,z+y
【2】A)x-y,x+yB)x+y,x-yC)z+y,z-yD)z-y,z+y
12.以下正确的描述是B__。
在C语言程序中A)函数的定义可以嵌套,但函数的调用不可以嵌套
B)函数的定义不可以嵌套,但函数的调用可以嵌套
C)函数的定义和函数的调用均不可以嵌套
D)函数的定义和函数的调用均可以嵌套
13.以下正确的说法是A__。
如果在一个函数中的复合语句中定义了一个变量,则该变量
A)只在该复合语句中有效
B)在该函数中有效
C)在本程序范围内均有效
D)为非法变量
14.凡是函数中未指定存储类型的局部变量,其隐含的存储类别为A__。
A)自动(auto)B)静态(static)
C)外部(extern)D)寄存器(register)
15.在一个C源程序文件中,若要定义一个只允许本源文件中所有函数使用的全局变量,则该变量需要使用的存储类别是D__。
A)externB)registerC)autoD)static
(二)填空题(50分)
1.若输入的值是-125,以下程序的运行结果是-5*5*5__。
intn;
scanf(“%d”,&
n);
printf(“%d=”,n);
if(n<
0)printf(“-”);
n=fabs(n);
fun(n);
fun(intn)
intk,r;
for(k=2;
k<
=sqrt(n);
k++)
{
r=n%k;
while(r==0)
{
printf(“%d”,k);
n=n/k;
if(n>
1)printf(“*”);
r=n%k;
}
}
if(n!
=1)printf(“%d\n”,n);
2.以下程序的运行结果是i=7;
j=6;
x=7
i=2;
j=7;
x=5。
inti=2,x=5,j=7;
fun(j,6);
printf(“i=%d;
j=%d;
x=%d\n”,i,j,x);
fun(inti,intj)
intx=7;
3.以下程序的运行结果是111__。
increment();
increment()
intx=0;
x+=1;
printf(“%d”,x);
4.以下程序的运行结果是maxis2_。
inta=1,b=2,c;
c=max(a,b);
printf(“maxis%d\n”,c);
max(intx,inty)
intz;
z=(x>
y)?
x:
y;
return(z);
5.以下程序的功能是根据输入的“y”(“Y”)与“n”(“N”),在屏幕上分别显示出“ThisisYES.”与“ThisisNO.”。
请填空。
voidYesNo(charch)
switch(ch)
case‘y’:
case‘Y’:
printf(“\nThisisYES.\n”);
_break_;
case‘n’:
case‘N’:
printf(“\nThisisNo.\n”);
charch;
printf(“\nEnterachar‘y’,‘Y’or‘n’,‘N’:
”);
ch=getchar();
printf(“ch:
%c”,ch);
YesNo(ch);
6.以下程序是选出能被3整除且至少有一位是5的两位数,打印出所有这样的数及其个数。
请选择填空。
sub(intk,intn)
inta1,a2;
a2=【1】__C__;
a1=k-【2】__A__;
if((k%3==0&
&
a2==5)||(k%3==0&
a1==5))
printf(“%d”,k);
n++;
returnn;
elsereturn-1;
intn=0,k,m;
for(k=10;
=99;
m=sub(k,n);
if(m!
=-1)n=m;
printf(“\nn=%d”,n);
【1】A)k*10B)k%10C)k/10D)k*10%10
【2】A)a2*10B)a2C)a2/10D)a2%10
7.以下程序的功能是用二分法求方程的根,并要求绝对误差不超过0.001。
floatf(floatx)
return(2*x*x*x-4*x*x+3*x-6);
floatm=-100,n=90,r;
r=(m+n)/2;
while(f(r)*f(n)!
=0)
if(f(m)*f(r)>
0)m=r;
elsen=r;
if(fabs(f(r))<
=0.001)break;
r=(m+n)/2;
printf(“Theisfangchengjieis%6.3f\n”,r);
8.以下程序的功能是计算下面函数的值。
floatf(float,float,float);
printf(“\ninputx,y,z:
\n”);
sum=f(x,x-y,x-z)+f(y,y-z,y-x)+f(z,z-x,z-y);
floatf(floata,floatb,floatc)
value=sin(a)/(sin(b)*sin(c));
9.以下程序的运行结果是输出如下图形。
*
***
*****
*******
voida(inti)
intj,k;
for(j=0;
j<
=5-i;
j++)printf(“”);
for(k=0;
2*i-1;
k++)printf(“*”);
printf(“\n”);
}
inti;
for(i=0;
i<
3;
i++)a(i);
for(i=3;
i>
=0;
i--)a(i);
10.以下程