程序设计基础基于C语言第2版课后习题参考答案Word文档下载推荐.docx
《程序设计基础基于C语言第2版课后习题参考答案Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《程序设计基础基于C语言第2版课后习题参考答案Word文档下载推荐.docx(78页珍藏版)》请在冰豆网上搜索。
程序的可测试性直接影响测试的质量和效率。
7、可维护性(Maintainability):
诊断和改正程序错误以及功能扩充和性能提高的容易程度。
程序设计是一个迭代过程,要开发出高质量的程序需要对程序进行多次修改和完善。
程序的可维护性决定了上述工作的质量和效率。
8、可重用性(Reusability):
可重用性是指在其它应用中该程序可以被再次使用的容易程度。
如果我们在开发新程序时,能够直接或稍加修改就能利用原有的程序,则会大大提高新程序开发的质量和效率。
因此,提高程序的可重用性是提高程序设计质量和效率的根本途径。
1.3计算题
(1)计算-1的8位原码、反码、补码和Excess_127码。
分别为:
10000001B、11111110B、11111111B、01111110B
(2)计算机内存中相邻四个字节的值为10111110000000000000000000000000,试问该值表示的实数、有符号数和无符号数各为多少?
分别是:
实数0.125、有符号数-1107296256(负数在计算机中用补码表示)无符号数3187671040
(3)字符‘A'
、‘a'
、‘1'
的ASCII值是多少,给出将大写字母的ASCII转换成对应小写字母ASCII值得计算公式。
‘A’:
41H‘a’:
61H‘1’:
31H
大写转化为小写:
大写字母的ASCII值+20H=小写字母的ASCII值
1.4为下列问题求解设计算法,并分别用程序流程图、N—S盒图和PAD图加以描述。
(1)有两个调料盒S1和S2,分别盛有糖和盐,要求将它们互换(即S1盒原来盛糖,现在改盛盐;
S2同理)。
算法思想:
这是一个两个变量交换值的问题,可以设置一个临时变量,首先把S1的值放入临时变量中,然后将S2的值放入S1中,最后将临时变量的值放入S1中即可。
程序流程图:
N-S盒图:
PAD图:
(2)依次输入6个整数,要求输出其中最小的数。
定义一个临时变量用来存放最小的数,首先输入第一个数赋值于临时变量,然后循环输入其余的整数,比较输入的整数和临时变量的大小,如果大于临时变量则继续输入,反之,则给临时变量赋值为次此数。
最后临时变量中存放的数输入的数中的最小数,输入临时变量即可。
(3)输入3个整数,按从大到小的顺序输出。
输入三个数a、b、c,首先比较a和b,如果a>
b,则比较c和a,如果c>
a则输出c、a、b;
如果c<
a,在比较c和b,如果c>
b,输出a、c、b,否则输出a、b、c;
对于a<
b的情况同理可以得出结果。
(4)求1*2*3*……*10。
算法思想:
定义一个变量用来存放最后的值,赋初值为1,做十次循环,每次循环在原来变量的基础上乘循环变量值(即1-10),最后输出这个变量即可。
(5)输入两个整数,求其最大公约数。
选取两个数中较小的数作为起始值,让这两个数分别除以这个值,如果可以整除,则这个数就是最后结果,如果不能整除则将起始值减一之后再用原来的两个数对其做除法运算,知道整除为止,得到的起始值的最后值就是结果。
1.5算法思考题
(1)钞票换硬币:
把一元钞票换成一分、二分、五分硬币(每种至少一枚),有哪些种换法?
分析:
1元相当于100分,设5分、2分、1分的硬币数分别为X、Y、Z,求换法就是在寻找这样一种组合,使得5*X+2*Y+Z=100,所以每当找到1种组合时,将个数记录下来,就可知换法有多少种,算法描述如下:
Count=0;
//用于记录个数,初始为0
for(X=1;
X<
=20;
X++)
for(Y=1;
Y<
=50;
Y++)
for(Z=1;
Z<
=100;
Z++)
{
if(5*X+2*Y+Z==100)//可实现交换
Count++;
}
输出Count
(2)百钱买百鸡:
一只公鸡值5元,一只母鸡值3元,3只小鸡值1元,现用一百元要买一百只鸡,问有什么方案?
分析:
由题意可知,假设公鸡、母鸡、小鸡分别有X、Y、Z只,那么X、Y、Z满足:
X+Y+Z=100,而且要满足钱数限定:
5*X+3*Y+1/3*Z=100,由于3只小鸡1元钱,所以小鸡的个数必须是3的整数倍,即:
Z是3的整数倍。
可通过限制条件,筛选出满足条件的X,Y,Z。
当然X、Y、Z还满足以下条件:
5*X<
=100;
3*Y<
Z<
=100。
以下是算法描述:
for(X=0;
for(Y=0;
for(Z=0;
if(5*X<
=100and3*Y<
=100andz%3==0)
if(X+Y+Z==100and5*X+3*Y+Z/3==100)
输出X、Y、Z;
(3)斐波那契兔子的问题:
某人有一对兔子饲养在围墙中,如果它们每个月生一对兔子,且新生的兔子在第二个月后也是每个月生一对兔子,问一年后围墙中共有多少对兔子。
第一个月是最初的一对兔子生下一对兔子,围墙内共有两对兔子。
第二个月仍是最初的一对兔子生下一对兔子,共有3对兔子。
到第三个月除最初的兔子新生一对兔子外,第一个月生的兔子也开始生兔子,因此共有5对兔子。
继续推下去,第12个月时最终共有对377对兔子。
由分析知,每个月的兔子都是上个月的兔子与新增兔子之和,而上个月新生的兔子到下个月才会生兔子,所以新增的兔子都是上两月的兔子生的。
设每个月的兔子数为F(n),则可列出下列式子:
F(0)=F
(1)=1
F(n)=F(n-1)+F(n-2)
显然可用递归的方法解出此题,算法流程图如下:
习题2参考答案
(1)请简要描述C语言的发展历史。
答:
C语言是一种目前世界上普遍流行、使用广泛的高级程序设计语言,它是在B语言的基础上发展起来的,1972—1973年间,贝尔实验室设计出了C语言。
1983年,美国国家标准化协会制定了C语言的标准,称为ANSIC。
(2)略。
(3)C语言的主要特点是什么?
答:
C语言的主要特点如下。
①C程序是由函数组成的。
②函数由函数头和函数体组成。
③C程序总是从main函数开始执行。
④每个语句和数据声明的最后必须有一个“;
”。
⑤C语言没有自己的输入/输出语句,它的输入/输出由库函数printf和scanf完成。
⑥可以添加注释。
⑦C语言程序中的变量必须先声明后使用。
(4)如何使用VisualC++6.0开发控制台程序?
使用VC6开发控制台程序的方法如下:
①在MiscrosoftVisualC++6.0环境下,首先建立一个空的工程。
②而后建立一个C源程序文件,并在该文件中输入源代码。
③使用Bulid命令或者快捷键F7,进行编译连接。
④如果没有错误,选择Execute命令或者快捷键Ctrl+F5,进行执行。
习题3参考答案:
3.1选择题
1.B2.D3.D4.A5.A6.A7.C8.C9.C10.B
3.2写出下列程序的输出结果
1.200310c8
2.a=100,b=200
3.97,141,61,a
4.
5.aabbcabc
4,3
6.6,6,6,7
3.3编程题
1.
#include<
stdio.h>
voidmain()
inta=500;
printf("
%d,%o,%x\n"
a,a,a);
输出结果:
500,764,1f4
2.
floatx;
scanf("
%f"
&
x);
a=%.3f,a=%.3e\n"
x,x);
输入:
66
a=66.000,a=6.60000e+001
3.
charch1='
a'
ch2=ch1;
%c,%d,%o,%x\n"
ch1,ch1,ch1,ch1);
ch2,ch2,ch2,ch2);
A,65,101,41
a,97,141,61
floatx,y,z,s,v;
%f%f%f"
x,&
y,&
z);
s=2*(x*y+x*z+y*z);
v=x*y*z;
Area=%.lf,Volume=%.lf\n"
s,v);
345
Area=94,Volume=60
5.
#definePI3.14
math.h>
floatr,s,l;
r);
s=(float)PI*r*r;
l=2*(float)PI*r;
r=%4.1f,s=%4.1f,l=%4.1f\n"
r,s,l);
3
r=3.0,s=28.3,l=18.8
6.
floatx1,y1,x2,y2,x3,y3,a,b,c,p,s;
%f%f%f%f%f%f"
x1,&
y1,&
x2,&
y2,&
x3,&
y3);
a=sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
b=sqrt((x1-x3)*(x1-x3)+(y1-y3)*(y1-y3));
c=sqrt((x2-x3)*(x2-x3)+(y2-y3)*(y2-y3));
p=(a+b+c)/2;
s=sqrt(p*(p-a)*(p-b)*(p-c));
Area=%f\n"
s);
5638023
Area=12.000013
习题4参考答案
4.1选择题。
(1)D
(2)A(3)A(4)C(5)C(6)B(7)B(8)B(9)C(10)A
4.2填空题。
(1)261
(2)16(3)0(4)2,1
4.3编程题。
(1)
#include<
floatc,f;
printf("
输入华氏温度:
\n"
);
scanf("
f);
c=(f-32)*5/9;
摄氏温度为:
%5.2f\n"
c);
(2)
string.h>
chars1[10],s2[10],s[20];
pleaseentertwostring\n"
gets(s1);
gets(s2);
strcat(s1,s2);
%s\n"
s1);
%d\n"
strlen(s1));
(3)
doublex,y;
pleaseentertwodata:
%lf%lf"
y);
%lfraisedto%lfis%lf\n"
x,y,pow(x,y));
习题5参考答案
1.填空题
(1)n=4
(2)2*i-1(3)7(4)######
2.#include<
voidmain()
longm,n,a,b,s;
\nPleaseinputvalueofM:
"
%ld"
m);
\nPleaseinputvalueofN:
n);
a=(m>
n)?
m:
n;
b=(m>
n:
m;
while(a%b!
=0)
{
s=a%b;
a=b;
b=s;
}
\nGongyueshu:
%ld\n"
\nGongBeishu:
(m*n)/s);
3.#include<
inta,b,c,d,e;
Pleaseinputaninteger:
%d"
a);
if(a/1000==0)
printf("
inputerror!
return;
b=a/1000;
e=a%10;
c=a%1000/100;
d=a%100/10;
if(b==e&
&
c==d)
YES.\n"
else
NO.\n"
4.#include<
intc;
intNum1,Num2,Num3,Num4;
Num1=Num2=Num3=Num4=0;
do
c=getchar();
if((c>
='
&
c<
z'
)||(c>
A'
Z'
))
Num1++;
elseif(c>
0'
9'
)
Num2++;
elseif(c=='
'
Num3++;
else
Num4++;
}while(c!
\n'
英文字母有%d个,数字有%d个,空格有%d个,其它字符有%d个。
Num1,Num2,Num3,Num4);
5.#include<
floata,b,c,disc,x1,x2,realpart,imagepart;
Inputa,bandc:
%f,%f,%f"
a,&
b,&
c);
Theequation"
disc=b*b-4*a*c;
if(fabs(disc)<
=1e-7)
hastwoequalroots:
%4.2f.\n"
-b/(2*a));
if(disc>
1e-7)
{
x1=(-b+sqrt(disc))/(2*a);
x2=(-b-sqrt(disc))/(2*a);
hasdistincerealroots:
%4.2fand%4.2f.\n"
x1,x2);
}
realpart=-b/(2*a);
imagepart=sqrt(-disc)/(2*a);
printf("
hascomplextroots:
%4.2f+%4.2fi"
realpart,imagepart);
and%4.2f-%4.2fi\n"
6.#include<
inti,j;
for(i=1;
i<
=5;
i++)
for(j=1;
j<
=i;
j++)
*"
for(i=5;
i>
=1;
i--)
for(j=i;
j>
j--)
7.#include<
#defineEPS1e-7
intn;
doublex,an,sum;
inputx:
%lf"
x=x*3.1415926/180;
sum=0;
an=x;
n=1;
sum+=an;
n=n*(n+1)*(n+2);
an*=(-x*x)/n;
an=%f\n"
an);
}while(fabs(an)>
=EPS);
sin(%.4lf)=%.4lf\n"
x,sum);
8.#include<
unsignedintn;
charc;
n=0;
inputabinaryinteger:
while((c=getchar())!
switch(c)
case'
:
n=n*2+0;
break;
1'
n=n*2+1;
thedecimalis%d.\n"
n);
9.#include<
10;
\t%d"
i);
i*j);
10.#include<
intn,m,z,x,y;
inputn:
m=n;
z=x=y=1;
while(n>
1)
z=x+y;
x=y;
y=z;
n--;
Fibonacci(%d)=%d.\n"
m,z);
11.#include<
intflag;
flag=1;
for(j=2;
=sqrt(i);
if(i%j==0)
{
flag=0;
break;
}
if(flag==1)
%d\t"
12.#include<
inti,sum;
=1000;
if(i%3==0&
i%5==0&
i%7==0)
sum+=i;
sumis%d.\n"
sum);
13.#include<
intx;
longf;
if(x>
=1&
x<
=3)
f=2*x+3;
elseif(x>
=4&
=10)
f=3*(x+4);
f=x*x+3*x-6;
f(%d)=%d\n