C语言程序设计-谭浩强-第三版-课后习题答案_第1页
C语言程序设计-谭浩强-第三版-课后习题答案_第2页
C语言程序设计-谭浩强-第三版-课后习题答案_第3页
C语言程序设计-谭浩强-第三版-课后习题答案_第4页
C语言程序设计-谭浩强-第三版-课后习题答案_第5页
已阅读5页,还剩68页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

C语言程序设计-谭浩强-第三版

一课后习题答案

1.5请参照本章例题,编写一个C程序,输出以下信息:

VeryGood!

解:

mian()

{printf(a**************************n);

printf("\n");

printf("VeryGood!\n");

printf("\n");

printf(a**************************n);

)

1.6编写一个程序,输入a、b、c三个值,输出其中最大值。

解:

mian()

{inta,b,c,max;

printf(“请输入三个数a,b,c:\n");

scanf("%d,%d,%d”,&a,&b,&c);

max=a;

if(max<b)

max=b;

if(max<c)

max=c;

printf("最大数为:"%d"max);

)

第三章

3.6写出以下程序运行的结果。

main()

{charcl='a,,c2=,b',c3='c',c4='\101',c5='\116';

printf(aa%cb%c\tc%c\tabc\nw,cl,c2,c3);

printf(w\t\b%c%c”,c4,c5);

}

解:

aatJbbMMLJccLJMLJLJMMabc

AUN

3.7要将“China”译成密码,译码规律是:用原来字母后面的第4个字母代替原

来的字母.例如,字母〃A〃后面第4个字母是〃E"."E〃代替"A〃。因此,"China"

应译为"Glmre"。请编一程序,用赋初值的方法使cl、c2、c3、c4、c5五个变

量的值分别为,'C,、'h,、'J、'd、'a,,经过运算,使cl、c2、

c3、c4、c5分别变为'G,、'1'、,、'r'、,e',并输出。

解:

itinclude<stdio.h>

main()

{charcl=,C,,c2='h',c3=,i',c4=,n,,c5='a';

cl+=4;

c2+=4;

c3+=4;

c4+=4;

c5+=4;

printf("密码是%c%c%c%c%c\n”,cl,c2,c3,c4,c5);

)

运行结果:

密码是Glmre

3.9求下面算术表达式的值。

(1)x+a%3*(int)(x+y)%2/4

设x=2.5,a=7,y=4.7

(2)(float)(a+b)/2+(int)x%(int)y

设a=2,b=3,x=3.5,y=2.5

(1)2.5

(2)3.5

3.10写出程序运行的结果。

main()

{inti,j,m,n;

i=8;

j=10;

m=++i;

n=j++;

printf("%d,%d,%d,%d”,i,j,m,n);

)

解:

9,11,9,10

3.12写出下面表达式运算后a的值,设原来a=12。设a和n都已定义为整型变

量。

(1)a+=a(2)a-=2(3)a*=2+3(4)a/=a+a

(5)a%=(n%=2),n的值等于5

(6)a+=a-=a*=a

解:

(1)24(2)10(3)60(4)0(5)0(6)0

第四章

4.4若a=3,b=4,c=5,x=l.2,y=2.4,z=-3.6,u=51274,n=128765,cl=,a',

c2=,b,。想得到以下输出格式和结果,请写出程序(包括定义变量类型和设

计输出)。

a=3b=4c=5

x=l.200000,y=2.400000,z=-3.600000

x+y=_3.600___y+z=-l.20___z+x=-2.40

cl='a'_or_97(ASCH)

c2='b'_or_98(ASCII)

main()

{inta=3,b=4,c=5;

longintu=51274,n=128765;

floatx=l.2,y=2.4,z=3.6;

charcl=,a',c2=,b,;

printf("a=%2db=%2dc=%2d\n”,a,b,c);

printf("x=%f,y=%f,z=%f\n〃,x,y,z);

printf("x+y=%5.2fy+z=%5.2fz+x=%5.2f\n”,x+y,y+z,z+x);

printf("u=%61dn=%91d\n”,u,n);

printf("%s%s%d%s\n","cl=‘a'","or",cl,"(ASCH)”);

printfC%s%s%d%s\n","c2='a'","or〃,c2,"(ASCII)”);

)

4.7用scanf下面的函数输入数据,使a=3,b=7,x=8.5,y=71.82,cl=xAz,

c2二'a',问在键盘上如何输入?

main()

{

inta,b;floatx,y;charclc2;

scanf("a=%d_b=%d",&a,&b);

scanf("_x=%f_y=%e",&x,&y);

scanf("_cl=%c_c2=%c",&cL&c2);

)

a=3__b=7

_x=8.5_y=71.82

_cl=A_c2=a

4.8链圆半径r=l.5,圆柱高h=3,求圆周长、圆面积、圆球表面积、圆球体积、

圆柱体积。用scanf输入数据,输出计算结果,输出时要求文字说明,取小数

点后两位数字。请编程序。

main()

{floatr,h,Cl,Sa,Sb,Va,Vb;

scanf("%f,%f",&r,&h);

Cl=2*3.14*r;

Sa=3.14*r*r;

Sb=4*Sa;

Va=4*3.14*r*r*r/3;

Vb=Sa*h;

printfCC1=%.2f\n",Cl);

printfCSa=%.2f\nSb=%.2f\nVa=%.2f\nVb=%.2f\n”,Sa,Sb,Va,Vb);

)

4.9输入一个华氏温度,要求输出摄氏温度。公式为

c=5(F-32)/9

输出要求有文字说明,取位2小数。

main()

{floatF,c;

scanf&F);

c=5*(F-32)/9;

printf("c=%.2f”,c);

)

4.10编程序,用getchar函数读入两个字符给cl、c2,然后分别用函数和函

数输出这两个字符。并思考以下问题:(1)变量cl、c2应定义为字符型或整形?

抑二者皆可?(2)要求输出cl和c2值的ASCII码,应如何处理?用putchar

函数还是printf函数?(3)整形变量与字符变量是否在任何情况下都可以互

相代替?如:

charcl,c2;

intcl,c2;

是否无条件的等价?

#include"stdio.h"

mainO

{charcl,c2;

cl=getchar();c2=getchar();

putchar(cl);putchar\n');putchar(c2);putchar(,\n');

}

#include*stdio.h"

main()

{charcl,c2;

cl=getchar();c2=getchar();

printf("cl=%dc2=%d\n*»cl,c2);

printf("cl=%cc2=%c\n”,cl,c2);

)

第五章

5.1什么是算术运算?什么是关系运算?什么是逻辑运算?

解:略。

5.2C语言中如何表示“真”和“假”?系统如何判断一个量的“真”和

“假”?

解:设有一个逻辑表达式,若其结果为“真”,则以1表示;若其结果为“假”,

则以0表示。但是判断一个逻辑量的值时,以0代表“真”,以非。代表“假”。

例如3&&5的值为“真”,系统给出3&&5的值为1»

5.3写出下面各逻辑表达式的值。设a=3,b=4,c=5»

(1)a+b>c&&b==c

(2)a||b+c&&b~c

(3)!(a>b)&&!c||1

(4)!(x=a)&&(y=b)&&0

(5)!(a+b)+c-l&&b+c/2

解:

(1)0

(2)1

(3)1

(4)0

(5)1

5.4有3个整数a、b、c,由键盘输入,输出其中最大的数。

解:

方法一

4include<stdio.h>

main()

{inta,b,c;

printf(〃请输入3个整数:〃);

scanf("%d,%d,%d",&a,&b,&c);

if(a<b)

if(b<c)printf("max=%d\n”,c);

elseprintf("max=%d\n”,b);

elseif(a<c)printf("max=%d\n”,c);

elseprintf("max=%d\n”,a);

)

方法二:使用条件表达式,可以使程序更加简明、清晰。

程序如下:

Sinclude<stdio.h>

main()

{inta,b,c,temp,max;

printf(〃请输入3个整数:”);

scanf("%d,%d,%d",&a,&b,&c);

temp=(a>b)?a:b;

max=(temp>c)?temp:c;

printf("3个整数的最大数是%d\n",max);

)

5.5有一函数:

写一程序,输入x值,输出y值。

解:

Sinclude<stdio.h>

main()

{intx,y;

printf("输入x:");

scanf&x);

if(x<l)

{y=x;

printf("x=%3d,y=x=%d\n”,x,y);

)

elseif(x<10)

{y=2*x-l;

printf("x=%3d,y=2*xT=%d\n”,x,y);

}

else

{y=3*x-ll;

printf("x=%3d,y=3*x-ll=%d\n/z,x,y);

)

}

5.6给一个百分制成绩,要求输出等级'A'、'B,、'C'、'D'、'E'。

90分以上为'A',80~90分为'B',70~79分为'C',60分以下为‘D'。

解:

程序如下:

^include<stdio.h>

main()

{floatscore;

chargrade;

case2:

printf(〃请输入学生成绩:〃);

scanf("%f”,&score);

while(score>100||(score<0)

{printf("\n输入有误,请重新输入:〃);

scanf("%f”,&score);

)

switch((int)(score/10))

{case10:

case9:grade.N;break;

case8:grade='B';break;

case7:grade—7;break;

case6:grade='D';break;

case5:

case4:

case3:

case1:

case0:grade.E’;

}

printf("成绩是%5.If,相应的等级是%c。\n",score,grade);

}

说明:对输入的数据进行检查,如小于0或大于100,要求重新输入。

(int)(score/10)的作用是将(score/10)的值进行强制类型转换,得到一个整

型值。

5.7给定一个不多于5位的正整数,要求:①求它是几位数;②分别打印出

每一位数字;③按逆序打印出各位数字。例如原数为321,应输出123。

解:

^include<stdio.h>

main()

{longintnum;

intindiv,ten,hundred,thousand,ten_thousand,place;

printf("请输入一个整数(0^99999):〃);

scanf&num);

if(num>9999)place=5;

elseif(num>999)place=4;

elseif(num>99)place=3;

elseif(num>9)place=2;

elseplace=l;

printf("place=%d\n",place);

ten_thousand=num/10000;

thousand=num/1000%10;

hundred=num/100%10;

ten=num%100/10;

indiv二num%10;

switch(place)

{case5:

printf(z,%d,%d,%d,%d,%d”,ten_thousand,thousand,hundred,ten,indiv);

printf("\n反序数字为;”);

printf("%d%d%d%d%d\n”,indiv,ten,hundred,thousand,ten_thousand);

break;

case4:printf("%d,%d,%d,%d”,thousand,hundred,ten,indiv);

printf(〃\n反序数字为:〃);

printf("%d%d%d%d\n”,indiv,ten,hundred,thousand);

break;

case3:printf("%d,%d,%d”,hundred,ten,indiv);

printf(〃\n反序数字为:〃);

printf("%d%d%d\n”,indiv,ten,hundred);

break;

case2:printf("%d,%d”,ten,indiv);

printf(〃\n反序数字为:”);

printf("%d%d\n”,indiv,ten);

break;

case1:printfindiv);

printf(〃\n反序数字为:〃);

printf("%d\n",indiv);

break;

)

)

5.8企业发放的奖金根据利润提成。利润I低于或等于10万元时,奖金可提成

10%;利润高于10万元,低于20万元(10000(X1W200000)时,其中10万元

按10%提成,高于10万元的部分,可提成7.5%;200000<1^400000时,其中

20万元仍按上述办法提成(下同),高于20万元的部分按5%提成;

400000<14600000时,高于40万元的部分按3%提成;600000〈IW1000000时,

高于60万的部分按1.5%提成;D1000000时,超过100万元的部分按1%提成。

从键盘输入当月利润I,求应发放奖金总数。要求:(1)用if语句编程序;(2)

用switch语句编程序。

解:计算利润时,要特别注意不同利润的不同提成比例。例如,利润为15万元,

其中有10万元按10%的比例提成,另外5万元则按7.5%提成。

(1)用if语句编程序。

ttinclude<stdio.h>

main()

{longi;

floatbonus,bonl,bon2,bon4,bon6,bonlO;

bonl=100000*0.1;

bon2=bon1+100000*0.075;

bon4=bon2+200000*0.05;

bon6=bon4+200000*0.03;

bon10=bon6+400000*0.015;

printf("请输入利润i:");

scanf&i);

if(i<=100000)

bonus=i*0.1;

elseif(i<=200000)

bonus=bonl+(i-100000)*0.075;

elseif(i<=400000)

bonus=bon2+(i-200000)*0.05;

elseif(i<=600000)

bonus=bon4+(i-400000)*0.03;

elseif(i<=1000000)

bonus=bon6+(i-600000)*0.015;

else

bonus=bonl0+(i-1000000)*0.01;

printf(”奖金是%10.2f\n”,bonus);

)

此题的关键在于正确写出每一区间的奖金计算公式。例如利润在10万元至20

万时,奖金应由两部分组成:①利润为10万元时应得的奖金。即100000x0.1;

②10万元以上部分应得的奖金。即(num-100000)X0.075。同理,20万〜40万

这个区间的奖金也应由两部分组成:①利润为20万元时应得的奖金,即100000

x0.1x1075x0.075;②20万元以上部分应得的奖金,即(num-200000)x0.05o

程序中先把10万、20万、40万、60万、100万各关键点的奖金计算出来,即

bonl、bon2、bon4、bon6、honlO;然后再加上各区间附加部分的奖金。

(2)用switch语句编程序。

输入利润i,确定相应的提成等级branch

根据branch确定奖金值

0奖金=i*0.1

1奖金=bonl+(i-105)*0.075

2奖金=bon2+(i-2*105)*0.05

3

4奖金=bon4+(i-4*105)*0.03

5

6奖金=bon6+(i-6*105)*0.015

7

8

9

10奖金=bonlO+(i-106)*0.01

输出奖金

Sinclude<stdio.h>

mainO

{longi;

floatbonus,bonl,bon2,bon4,bon6,bonlO;

intc;

bonl=100000*0.1;

bon2=bonl+100000*0.075;

bon4=bon2+200000*0.05;

bon6=bon4+200000*0.03;

bon10=bon6+400000*0.015;

printf("请输入利润i:”);

scanf&i);

c=i/100000;

if(c>10)c=10;

switch(c)

{case0:bonus=l*0.1;break;

case1:bonus=bonl+(i-100000)*0.075;break;

case2:

case3:bonus=bon2+(i-200000)*0.05;break;

case4:

case5:bonus=bon4+(i-400000)*0.03;break;

case6:

case7:

case8:

case9:bonus=bon6+(i-600000)*0.015;break;

case10:bonus=bonl0+(i-1000000)*0.01;

)

printf("奖金是%10.2f”,bonus);

}

5.9输入4个整数,要求按由大到小的顺序输出。

解:此题采用依次比较的方法排出其大小顺序。在学习了循环和数组以后,可

以有更多的排序方法。

#include<stdio.h>

main()

{intt,a,b,c,d;

printf(”请输入4个整数:〃);

scanf("%d,%d,%d,%d",&a,&b,&c,&d);

printf("\na=%d,b=%d,c=%d,d=%d\n”,a,b,c,d);

if(a>b){t=a;a=b;b=t;}

if(a>c){t=a;a=c;c=t;}

if(a>d){t=a;a=d;d=t;}

if(b>c){t=a;b=c;c=t;}

if(b>d){t=b;b=d;d=t;}

if(c>d){t=c;c=d;d=t;}

printf(〃排序结果如下:\n〃);

printf("%d,%d,%d,%d\n”,a,b,c,d);

5.10有4个圆塔,圆心分别为(2,2)、(-2,2)、(2,-2)、(-2,-2),圆半径

为1。这4个塔的高度分别为10m。塔以外无建筑物。今输入任一点的坐标,求

该点的建筑高度(塔外的高度为零)。

程序如下:

4include<stdio.h>

main()

{inth=10;

floatxl=2,yl=2,x2=-2,y2=2,x3=-2,y3=-2,x4=-2,y4=-2,x,y,dl,d2,d3,d4;

printf("请输入一个点(x,y):");

scanf("%f,%f",&x,&y);

dl=(x-xl)*(x-xl)+(y-y1)*(y-yl);

d2=(x-x2)*(x-x2)+(y+y2)*(y+y2);

d3=(x+x3)*(x+x3)+(y-y3)*(y-y3);

d4=(x+x4)*(x-x4)*(y+y4)*(y+y4);

if(dl>l&&d2>l&&d3>l&&d4>l)h=0;

printf("该点高度为%d\n",h);

第六章

第六章循环控制

6.1输入两个正整数m和n,求其最大公约数和最小公倍数。

main()

{longm,n,i=l,j,s;

scanf%ld",&m,&n);

for(;i<=m&&i<=n;i++)

{if(m%i=0&&n%i=0)s=i;}

if(m>=n)j=m;

elsej=n;

for(;!(j%m==0&&j%n==0);j++);

printf("s=%ld,j=%ld\n”,s,j);

}

6.2输入一行字符,分别统计出其中英文字母、空格、数字和其他字符的个数。

#include"stdio'h”

main()

{charc;inti=0,j=0,k=0,1=0;

while((c=getchar())!=,\n,)

{if(c>=65&&c<=90||c>=97&&c<=122)i++;

elseif(c>=48&&c<=57)j++;

elseif(c==32)k++;

else1++;}

printf(*i=%d,j=%d,k=%d,l=%d\n”,i,j,k,1);

)

6.3求Sn=a+aa+aaa+…+aa…aaa(有n个a)之值,其中a是一个数字。例如:

2+22+222+2222+22222(n=5),n由键盘输入。

ttinclude^math.h"

main()

{intn,sum=0,i=l,s=2;

scanf&n);

while(i<=n)

{sum=sum+s;s=s+2*pow(10,i);

i++;}

printf("sum=%d\n”,sum);

)

6.4求,(即求1!+2!+3!+4!+5!+…+20!)

main()

{intn,i=l;longsum=0,s=l;

scanf&n);

while(i<=n){s=s*i;sum=sum+s;i++;}

printf("sum=%ld\n”,sum);

}

6.5求

mainO

{doublei=l,j=l,k=l,sl=0,s2=0,s3=0,sum;

for(;i<=100;i++)sl=sl+i;

for(;j<=50;j++)s2=s2+j*j;

for(;k<=10;k++)s3=s3+l/k;

sum=sl+s2+s3;

printf("sum=%f\n”,sum);

}

6.6打印出所有〃水仙花数〃,所谓〃水仙花数〃是指一个三位数,其各位数字立方

和等于该本身。例如:153是一个水仙花数,因为153=厂3+5-3+3-3。

ttinclude^math.h"

main()

{intx=100,a,b,c;

while(x>=100&&x<1000){a=0.01*x;b=10*(0.01*x-a);c=x-100*a-10*b;

if(x==(pow(a,3)+pow(b,3)+pow(c,3)))printf("%5d”,x);x++;}

)

6.7一个数如果恰好等于它的因子之和,这个数就称为〃完数〃。例如,6的因子

为1、2、3,而6=1+2+3,因此6是"完数"。编程序找出1000之内的所有完数,

并按下面格式输出其因子:

6itsfactorsare1、2、3

main()

{intm,i,j,s;

for(m=6;m<10000;m++)

{s=l;

for(i=2;i<m;i++)

if(m%i==0)s=s+i;

if(m-s==0)

{printf("%5ditsfastorsare1”,m);for(j=2;j<m;j++)if(m%j==0)

printf(z,%d",j);printf("\n");}

}

)

main()

{intm,i,j,s;

for(m=6;m<1000;m++)

{s=m-l;

for(i=2;i<m;i++)

if(m%i==O)s=s-i;

if(s==0)

{printf(^%5ditsfastorsare1m);for(j=2;j<m;j++)if(m%j==0)

printf("%d",j);printf("\n");}

}

}

6.8有一分数序列:

求出这个数列的前20项之和。

main()

{inti=l,n;doublet,x=l,y=2,s,sum=0;

scanf("断d”,&n);

while(i<=n){s=y/x;sum=sum+s;t=y;y=y+x;x=t;i++;}

printf("%f\n",sum);

}

6.9一球从100米高度自由下落,每次落地后返回原高度的一半,再落下。求它

在第10次落地时共经过多少米?第10次反弹多高?

main()

{inti,n;doubleh=100,s=100;

scanf&n);

for(i=l;i<=n;i++)

{h*=0.5;if(i=l)continue;s=2*h+s;}

printf("h=%f,s=%f\n”,h,s);

}

6.10猴子吃桃问题。猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,

又多吃了一个。第二天早上又将剩下的桃子吃掉一半,又多吃一个。以后每天

早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,见只剩下一个

桃子了。求第一天共摘多少桃子。

main()

{inti=l,sum=0;

for(;i<=10;sum=2*sum+l,i++);

printf("sum=%d\n”,sum);

)

6.11用迭代法求。求平方根的迭代公式为:

要求前后两次求出的得差的绝对值少于0.00001o

#include"math・h”

main()

{floatxO,xl,a;

scanf&a);

xl=a/2;

do

{x0=xl;xl=(xO+a/xO)/2;}

while(fabs(xO-xl)>=O.OOOO1);

printf(“先3f\n",xl);

)

6.12用牛顿迭代法求方程在1.5附近的根。

main()

{doublex,y;x=l.5;

do{y=2*x*x*x-4*x*x+3*x-6;

x=x-y/(6*x*x-8*x+3);}

while(y!=0);

printf("x=%.3f\n”,x);

}

6.13用二分法求方程在(TO,10)之间的根

main()

{doublexl,x2,yl,y2;xl=-10;x2=10;

do{y1=2*x1*x1*x1-4*x1*x1+3*x1-6;

xl=xl-yl/(6*xl*xl-8*xl+3);}

while(yl!=0);

do

{y2=2*x2*x2*x2-4*x2*x2+3*x2-6;

x2=x2-y2/(6*x2*x2-8*x2+3);}

while(y2!=0);

printf("xl=%,3f,x2=%.3f\n",xl,x2);

}

6.14打印以下图案

*

***

*****

*******

*****

***

*

ttinclude^math.h"

main()

{inti,j,k;

for(i=0;i<=3;i++)

{for(j=0;j<=2-i;j++)

printf(*");

for(k=0;k<=2*i;k++)

printf(***);

printf("\n〃);

for(i=0;i<=2;i++)

{for(j=0;j<=i;j++)

printfC");

for(k=0;k<=4-2*i;k++)

printf(〃*");

printf("\n");

)

)

第七章

第七章数组

7.1用筛法求之内的素数。

main()

{inti,j,a[100];

for(i=2;i<100;i++)

{a[i]=i;

for(j=2;j<=i;j++)

{if(j<i)

if(a[i]%j==0)

break;

if(a[i]-j==0)

printf("%5d",a[i]);

)

)

printf("\n");

)

#include*math.h"

main()

{staticinti,j,k,a[98];

for(i=2;i<100;i++)

{a[i]=i;k=sqrt(i);

for(j=2;j<=a[i];j++)

if(j<k)if(a[i]%j=O)

break;

if(j>=k+l)

printf("%5d",a[i]);

)

printf(*Xn*);

)

7.2用选择法对10个整数从小到大排序。

main()

{inti,j,a[10],t;

for(i=0;i<10;i++)

scanf("%d”,&a[i]);

for(j=l;j<10;j++)

for(i=0;i<=9-j;i++)

if(a[i]>a[i+l])

{t=a[i+l];a[i+l]=a[i];a[i]=t;}

for(i=0;i<10;i++)

printf(*%5d*»a[i]);

)

mainO

{staticinta[10],i,j,k,t;

for(i=l;i<ll;i++)

scanf("%d”,&a[i]);

for(j=l;j<10;j++)

for(i=l;i<=10-j;j++)

if(a[i]>a[i+l])

{t=a[i+l];a[i+l]=a[i];a[i]=t;}

for(i=l;i<ll;i++)

printfa[i]);

printf("\n");

)

7.3求一个3X3矩阵对角线元素之和。

main()

{inti=0,j=0,a[3][3],si,s2;

for(i=0;i<3;i++)

for(j=0;j<3;j++)

scanf("%d”,&a[i][j]);

sl=a[0][0]+a[l][l]+a[2][2];

s2=a[0][2]+a[l][l]+a[2][0];

printf(*sl=%d,s2=%d\n”,si,s2);

)

main()

(

staticinti,j,si,s2,a[3][3];

for(i=l;i<=3;i++)

for(j=l;j<=3;j++)

scanf&a[i][j]);

sl=a[l][l]+a[2][2]+a[3][3];

s2=a[l][3]+a[2][2]+a[3][l];

printf("%d,%d\n”,si,s2);

)

7.4已有一个已排好的数组今输入一个数要求按原来排序的规律将它插入数组

中。

main()

{staticinta[10]={l,7,8,17,23,24,59,62,101};inti,j,t;

scanf&a[9]);

for(i=9;i>0;i—)

if(a[i]<a[i-ll)

{t=a[i-l];a[i-l]=a[i];a[i]=t;}

for(i=0;i<10;i++)

printf("%5d",a[i]);printf("\n");

)

main()

(

staticinta[5]={l,4,5,6,7};

inti,t,b;

scanf("%d",&b);

for(i=0;i<5;i++)

{if(b<=a[i])

{t=a[i];a[i]=b;b=t;}

printf(*%d”,a[i]);}

printfb);

)

7.5将一个数组的值按逆序重新存放,例如,原来顺序为:8,6,5,4,1»要

求改为:1,4,5,6,8o

main()

{inti,b[10];

for(i=0;i<10;i++)

scanf("%d”,&b[i]);

for(i=9;i>-l;i—)

printf("%5d",b[i]);

printf("\n");}

7.6打印出以下杨辉三角形(要求打印出10行)。

1

11

121

1331

14641

15101051

main()

(

staticintm,n,k,b[15][15];

b[0][l]=l;

for(m=l;m<15;m++)

(

for(n=l;n<=m;n++)

(

b[m][n]=b[m-l][n-l]+b[m-l][n];

printf("%-5d”,b[m][n]);

)

printf("\n〃);

)

)

)

mainO

{inti,j,n,k,a[10][10];

statica[][l]={{l},{1},{1},{1},{1},{1},{1},{1},{1},{1}};

a[l][1]=1;

for(k=2,k<ll;k++)

for(i=2;i<=k;i++)

for(j=2;j<=i;j++)

a[i][j]=a[i-l][j-l]+a[i-l][j];

for(k=l;k<ll;k++)

for(i=l;i<=k;i++)

for(j=l;j<=i;j++)

printfa[i][j]);

)

7.7打印“魔方阵”,所谓魔方阵是指这样的方阵,它的每一行、每一列和对

角线之和均相等。例如,三阶魔方阵为

816

357

492

要求打印出由1〜n2的自然数构成的魔方阵。

解:

#include<stdio.h>

main()

{inta[16][16],i,i,k,p,m,n;

P=l:

while(p=l)

{printf(*Entern(n=l~15):”);

scanf&n);

if((n!=0)&&(n<=15)&&(n%2!=0))p=0;

)

for(i=l;i<=n;i++)

for(j=l;j<=n;j++)a[i][j]=0

7-8

#include<iostream>

voidmain()

inta[4][4],i,j,max,min,kl,k2,flag:

printf("输入一个4*4的数组"也");

for(i=0;i<4;i++)

(

for(j=0;j<4;j++)

(

scanf(*%d*,&a[i][j]):

)

)

printf("鞍点为:\n\n");

for(i=0;i<4;i++)

{

max=a[i][0];

for(j=0;j<4;j++)

|

if(max<=a[i][j])

(

max=a[i][j];

kl=j;

)

)

min=a[0][kl];

for(j=0;j<4;j++)

(

if(min>=a[j][kl])

(

min=a[j][kl];

k2=j;

)

)

if((max!=min))flag=0;

else

(

flag=l;

printf("%d\n",max);

break;

)

if(flag==0)printf("不存在\n\n");

7-9

#include<iostream>

voidmain()

(

floata[15]={100,98,65,55,34,23,23,12,11,9,7,6,4,3,2},n;

inti,low,high,mid;

printf("原数组为:\n\n");

for(i=0;i<15;i++)

(

printf("%6.2f”,a[i]);

)

printf("\n\n输入一个数n\n\n");

scanf("%f",&n);

low=0;

high=14;

i=0;

whi1e(1ow<=high)

(

mid=(low+high)/2;

if(a[mid]==n)

(

printf("该数是数组中第%d个元素\n\n”,mid+1);

i++;

break;

)

elseif(a[mid]<n)high=mid-l;

elselow=mid+l;

)

if(i==0)printf("无此数。\n\n");

)

7-10

#include<iostream>

voidmain()

(

chara[3][80];

inti,j,upon=0,low=0,num=0,spa=0,oth=0;

for(i=0;i<3;i++)

printf(〃输入第%d行文字\n\n",i);

gets(a[i]);

for(j=0;j<80&&a[i][j]!='\0';j++)

if(a[i][j]>=,A*&&a[i][j]<='Z')upon+=l;

elseif(a[i][j]>=,a&&a[i][j]<=,z')low+=l;

elseif(a[i][j]>=48&&a[i][j]<=57)num+=l;

elseif(a[i][j]=,')spa+=l;

elseoth+=l;

)

)

printf("英文大写字母:%d个\n\n”,upon);

printf("英文小写字母:%d个\n\n”,low);

printf("数字:%d个\n\n”,num);

printf("空格:%d个\n\n”,spa);

printf(〃其他字符:%d个\11\11”,oth);

)

7-11

#include<iostream>

voidmain()

(

inti,j;

for(i=0;i<5;i++)

(

for(j=0;j<=i;j++)

(

printf("");

)

for(j=i;j<i+5;j++)

(

printf。*;

)

printf("\n");

)

)

7-12

#include<iostream>

voidmain()

(

chara[80],b[80];

inti,j;

printf("输入密码也也");

gets(a);

for(i=0;i<80&&a[i]!-\0*;i++)

(

if((a[i]>=,A,)&&(a[i]<=,Z'))

(

b[i]=155-a[i];

)

elseif((a[i]>=,a')&&(a[i]<='z'))

|

b[i]=219-a[i];

)

elseb[i]=a[i];

)

b[i]八O';

printf("密文为:\n\n*);

puts(a);

printf("原文为:\n\n*);

puts(b);

7-13

^include<iostream>

voidmain()

(

chara[80],b[80];

inti,j,k;

printf(〃输入第1个字符串\n\n〃);

gets(a),

printf(:输入第2个字符串\n\n〃);

gets(b);

for(i=0;i<80;i++)

(

if(a[i]—\0,)

(

k=i;

for(j=0;j<80&&b[j]!='\0';j++)

(

a[k]=b[j];

k++;

)

a[k]=\0,;

break;

}

printf(〃连接后字符串为:\n\n");

puts(a);

7-14

4include<iostream>

voidmain()

(

chara[80],b[80];

inti,j,k;

printf("输入第1个字符串\n\n");

gets(a);

printf("输入第2个字符串\n\n");

gets(b);

for(i=0;(i<80)&&(a[i]!=\0*)&&(b[i]!=\0*);i++)

(

k=a[i]-b[i];

if(k>0)

(

printfC\n\n字符串a大于字符串b:%4d\n\n",k);

break;

)

elseif(k<0)

{

printf("\n\n字符串a小于字符串b:%4d\n\n",k);

break;

)

elsek=0;

)

if(k==O)printfC\n\n字符串a等于字符串b:%4d\n\n",k);

}

7-15

4include<iostream>

voidmain()

(

charsi[80],s2[80];

inti,j;

printf("输入数组sl\n\n");

gets(si):

printf("输入数组s2\n\n");

gets(s2);

for(i=0;i<80&&s2[i]!=\0J;i++)

(

sl[i]=s2[i];

)

sl[i]-\0*;

printf("\n\n复制后的数组为:\n\n");

puts(si);

)

第八章

8-1

^include<iostream>

voidmain()

{

intmax_div(int,int);

intmin_mul(int,int);

intm,n;

printf("输入两个整数\n\n");

scanf("%d%d”,&m,&n);

if(max_div(m,n)==0)printf("\n\n无最大公约数为、n\n");

elseprintf("\n\n最大公倍数为:%d\n\n",max_div(m,n));

printf("\n\n最大公倍数为:%d\n\n",min_mul(m,n));

)

intmax_div(intkl,intk2)

(

intmin(int,int);

inti,k,flag;

k=min(kl,k2);

for(i=k;i>l;i-)

(

if((kl%i=0)&&(k2%i==0))

(

return(i);

flag=l;

break;

)

elseflag=0;

)

if(flag=0)return(0);

)

intmin_mul(intkl,intk2)

intmax(int,int);

inti,k;

k=max(kl,k2);

for(i=k;;i++)

(

if((i%kl==O)&&(i%k2==0))

(

return(i);

break;

)

)

}

intmin(intkl,intk2)

(

intmin;

min=kl;

if(kl>k2)min=k2;

return(min);

)

intmax(intkl,intk2)

(

intmax;

max=kl;

if(kl<k2)max=k2;

return(max);

)

8-2

^include<iostream>

^include<math.h>

voidmain()

(

voidrootl(float,float,float);

voidroot2(float,float,float);

voidroot3(float,float,float);

floata,b,c,k;

printf("输入a,b,c的值\n\n");

scanf",&a,&b,&c);

k=b*b-4*a*c;

if(k>0)rootl(a,b,c);

elseif(k==0)root2(a,b,c);

elseroot3(a,b,c);

)

voidrootl(floata,floatb,floatc)

floatp,q;

p=-b/(2*a);

q=sqrt(b*b-4*a*c)/(2*a);

printf("\n\n方程的两个根为:xl=%6.2f,x2=%6.2f\n\n”,p+q,p-q);

}

voidroot2(floata,floatb,floatc)

(

floatp;

p=-b/(2*a);

printf("\n\n方程的两个根为:xl=x2=%6.2f\n\n",p);

)

voidroot3(floata,floatb,floatc)

(

floatp,q;

p=-b/(2*a);

q=sqrt(-b*b+4*a*c)/(2*a);

printf(*\n\n方程的两个根为

xl=%6.2f+%6.2fi,x2=%6.2f-%6.2fi\n\n*,p,q,p,q);

)

8-3

Sinclude<iostream>

voidmain()

(

intprime(int);

intx;

printf("输入一个正整数\n\n〃);

scanf&x);

if(prime(x)==0)printf("\n\n此数为素数\n\n");

elseprintf("\n\n此数不是素数\n\n");

)

intprime(intx)

(

inti,flag;

for(i=2;i<x;i++)

(

if(x%i==0)

(

flag=l;

break;

)

elseflag=0;

return(flag);

)

8-4

#include<iostream>

voidmain()

(

voidexchange(inta[3][3]);

inta[3][3],i,j;

printf("输入一个3*3的矩阵\n\n");

for(i=0;i<3;i++)

(

for(j=0;j<3;j++)

(

scanf&a[i][j]);

)

)

exchange(a);

printf("\n\n转置后的矩阵为:\n\n");

for(i=0;i<3;i++)

(

for(j=0;j<3;j++)

(

printf(*%d*,a[i][j]);

)

printf(〃\n");

)

)

8-5

#include<iostream>

voidmain()

(

voidexchange(charstr[]);

charstr[80];

printf("输入一个字符串\n\n");

gets(str);

exchange(str);

printf("\n\n反序字符串为:\n\n");

puts(str);

)

voidexchange(charstr[])

inti,j,k;

chartemp;

for(i=0;;i++)

(

if(str[i]=='\0')break;

)

k=i/2;

for(j=0;j<=k;j++)

(

temp=str[j];

str[j]=str[i-l-j];

str[i-l-j]=temp;

)

str[i]=\0J;

)

8-6

#include<iostream>

voidmain()

(

voidstrcat(charstrl[],charstr2[]);

charstrl[80],str2[80];

printf("输入strl\n\n*);

gets(strl);

printf("\n\n输入str2\n\n");

gets(str2);

strcat(strl,str2);

printf(*\n\n连接后的字符串为:\n\n");

puts(strl);

}

voidstrcat(charstrl[],charstr2[])

(

inti,j;

for(i=0;;i++)

(

if(strl[i]=\0J)

(

for(j=0;str2[j]!=>\0*;j++)

(

strl[i]=str2[j];

i+=l;

)

break;

)

strl[i]-\0*;

)

8-7

#include<iostream>

voidmain()

(

voidstrcpy(charstrl[],charstr2[]);

charstrl[80],str2[80];

printf("输入str2\n\n");

gets(str2);

strcpy(strl,str2);

printf("\n\n复制后的字符串为:\n\n");

puts(strl);

)

voidstrcpy(charstrl[],charstr2[])

(

inti,j=0;

for(i=0;str2[i]!=>\0*;i++)

(

if((str2[i]==a)II(str2[i]=e)II(str2[i]=i*)||(str2[i]='o'

)II(str2[i]==u))

(

strl[j]=str2[i];

j++;

)

)

strl[j]-\0*;

)

8-8

#include<iostream>

voidmain()

(

voidstradd(charstr[]);

charstr[80];

printf("输入一串数字\n\n");

gets(str);

stradd(str);

printfC\n\n加空格后的字符串\n\n〃);

puts(str);

}

voidstradd(charstr口)

chara[80];

inti=0,j;

for(j=0;str[j]!-\0J;j++)

(

a[i]=str[j];

a[i+l]='

i+=2;

)

a[i]-\0*;

for(i=0;a[i]!='\0';i++)

(

str[i]=a[i];

)

str[i]-\0';

8-9

Sinclude<iostream>

voidmain()

voidnum(charstr口,inta[]);

charstr[80];

inta[4]={0};

printf("输入一个字符串\n\n");

gets(str);

num(str,a);

printf("字母个数为:%d\n”,a[0]);

printf(〃数字个数为:%d\n",a[l])

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论