书签 分享 收藏 举报 版权申诉 / 131
上传文档赚钱

类型《c-程序设计方案》谭浩强课后习题答案(DOC 131页).doc

  • 上传人(卖家):2023DOC
  • 文档编号:5853904
  • 上传时间:2023-05-12
  • 格式:DOC
  • 页数:131
  • 大小:340.50KB
  • 【下载声明】
    1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
    2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
    3. 本页资料《《c-程序设计方案》谭浩强课后习题答案(DOC 131页).doc》由用户(2023DOC)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
    4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
    5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
    配套讲稿:

    如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。

    特殊限制:

    部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。

    关 键  词:
    c-程序设计方案 c-程序设计方案谭浩强课后习题答案DOC 131页 程序设计 方案 谭浩强 课后 习题 答案 DOC 131
    资源描述:

    1、第一章1.5题#include using namespace std。int main() coutThisis。 coutaC+。 coutprogram.。 return 0。1.6题#include using namespace std。int main() int a,b,c。 a=10。 b=23。 c=a+b。 couta+b=。 coutc。 coutendl。 return 0。1.7七题#include using namespace std。int main() int a,b,c。 int f(int x,int y,int z)。 cinabc。 c=f(a,b,c

    2、)。 coutcendl。 return 0。int f(int x,int y,int z) int m。 if (xy) m=x。 else m=y。 if (zm) m=z。 return(m)。 1.8题#include using namespace std。int main() int a,b,c。 cinab。 c=a+b。 couta+b=a+bendl。 return 0。1.9题#include using namespace std。int main() int a,b,c。 int add(int x,int y)。 cinab。 c=add(a,b)。 couta+b

    3、=cendl。 return 0。int add(int x,int y)int z。 z=x+y。 return(z)。2.3题#include using namespace std。int main() char c1=a,c2=b,c3=c,c4=101,c5=116。 coutc1c2c3n。 couttbc4tc5n。 return 0。2.4题#include using namespace std。int main() char c1=C,c2=+,c3=+。 coutI say: c1c2c3。 coutttHe says: C+ is very interesting! n

    4、。 return 0。2.7题#include using namespace std。int main()int i,j,m,n。 i=8。 j=10。 m=+i+j+。 n=(+i)+(+j)+m。 coutitjtmtnendl。 return 0。2.8题#include using namespace std。int main()char c1=C, c2=h, c3=i, c4=n, c5=a。 c1+=4。 c2+=4。 c3+=4。 c4+=4。 c5+=4。 coutpassword is:c1c2c3c4c5endl。 return 0。3.2题#include #incl

    5、ude using namespace std。int main ( )float h,r,l,s,sq,vq,vz。 const float pi=3.1415926。 coutrh。 l=2*pi*r。 s=r*r*pi。 sq=4*pi*r*r。 vq=3.0/4.0*pi*r*r*r。 vz=pi*r*r*h。 coutsetiosflags(ios:fixed)setiosflags(ios:right) setprecision(2)。 coutl= setw(10)lendl。 couts= setw(10)sendl。 coutsq=setw(10)sqendl。 coutvq

    6、=setw(10)vqendl。 coutvz=setw(10)vzendl。 return 0。 3.3题#include using namespace std。int main ()float c,f。 coutf。 c=(5.0/9.0)*(f-32)。 /注意5和9要用实型表示,否则5/9值为0 cout摄氏温度为:cendl。 return 0。3.4题#include using namespace std。int main ( )char c1,c2。 cout请输入两个字符c1,c2:。 c1=getchar()。 /将输入的第一个字符赋给c1 c2=getchar()。 /

    7、将输入的第二个字符赋给c2 cout用putchar函数输出结果为:。 putchar(c1)。 putchar(c2)。 coutendl。 cout用cout语句输出结果为:。 coutc1c2endl。 return 0。3.4题另一解#include using namespace std。int main ( )char c1,c2。 cout请输入两个字符c1,c2:。 c1=getchar()。 /将输入的第一个字符赋给c1 c2=getchar()。 /将输入的第二个字符赋给c2 cout用putchar函数输出结果为:。 putchar(c1)。 putchar(44)。 p

    8、utchar(c2)。 coutendl。 cout用cout语句输出结果为:。 coutc1,c2endl。 return 0。3.5题#include using namespace std。int main ( )char c1,c2。 int i1,i2。 /定义为整型 couti1i2。 c1=i1。 c2=i2。 cout按字符输出结果为:c1 , c2endl。 return 0。3.8题#include using namespace std。int main ( ) int a=3,b=4,c=5,x,y。 coutc & b=c)endl。 cout(a|b+c & b-c

    9、)endl。 coutb) & !c|1)endl。 cout(!(x=a) & (y=b) & 0)endl。 cout(!(a+b)+c-1 & b+c/2)endl。 return 0。 3.9题include using namespace std。int main ( ) int a,b,c。 coutabc。 if(ab) if(bc) coutmax=c。 else coutmax=b。 else if (ac) coutmax=c。 else coutmax=a。 coutendl。return 0。 3.9题另一解#include using namespace std。in

    10、t main ( ) int a,b,c,temp,max 。 coutabc。 temp=(ab)?a:b。 /* 将a和b中的大者存入temp中 */ max=(tempc)?temp:c。 /* 将a和b中的大者与c比较,最大者存入max */ coutmax=maxendl。 return 0。 3.10题#include using namespace std。int main ( ) int x,y。 coutx。 if (x1) y=x。 coutx=x, y=x=y。 else if (x10) / 1x10 y=2*x-1。 coutx=x, y=2*x-1=y。 else

    11、/ x10 y=3*x-11。 coutx=x, y=3*x-11=y。 coutendl。return 0。3.11题#include using namespace std。int main () float score。 char grade。 coutscore。 while (score100|score0) coutscore。 switch(int(score/10) case 10: case 9: grade=A。break。 case 8: grade=B。break。 case 7: grade=C。break。 case 6: grade=D。break。 defaul

    12、t:grade=E。 coutscore is score, grade is gradeendl。 return 0。3.12题#include using namespace std。int main ()long int num。 int indiv,ten,hundred,thousand,ten_thousand,place。 /*分别代表个位,十位,百位,千位,万位和位数 */ coutnum。 if (num9999) place=5。 else if (num999) place=4。 else if (num99) place=3。 else if (num9) place=

    13、2。 else place=1。 coutplace=placeendl。 /计算各位数字 ten_thousand=num/10000。 thousand=(int)(num-ten_thousand*10000)/1000。 hundred=(int)(num-ten_thousand*10000-thousand*1000)/100。 ten=(int)(num-ten_thousand*10000-thousand*1000-hundred*100)/10。 indiv=(int)(num-ten_thousand*10000-thousand*1000-hundred*100-ten

    14、*10)。 coutoriginal order:。 switch(place) case 5:coutten_thousand,thousand,hundred,ten,indiven dl。 coutreverse order:。 coutindivtenhundredthousandten_thousandendl。 break。 case 4:coutthousand,hundred,ten,indivendl。 coutreverse order:。 coutindivtenhundredthousandendl。 break。 case 3:couthundred,ten,indi

    15、vendl。 coutreverse order:。 coutindivtenhundredendl。 break。 case 2:coutten,indivendl。 coutreverse order:。 coutindivtenendl。 break。 case 1:coutindivendl。 coutreverse order:。 coutindivendl。 break。 return 0。 3.13题#include using namespace std。int main () long i。 /i为利润 float bonus,bon1,bon2,bon4,bon6,bon1

    16、0。 bon1=100000*0.1。 /利润为10万元时的奖金 bon2=bon1+100000*0.075。 /利润为20万元时的奖金 bon4=bon2+100000*0.05。 /利润为40万元时的奖金 bon6=bon4+100000*0.03。 /利润为60万元时的奖金 bon10=bon6+400000*0.015。 /利润为100万元时的奖金 couti。 if (i=100000) bonus=i*0.1。 /利润在10万元以内按10%提成奖金 else if (i=200000) bonus=bon1+(i-100000)*0.075。 /利润在10万元至20万时的奖金 e

    17、lse if (i=400000) bonus=bon2+(i-200000)*0.05。 /利润在20万元至40万时的奖金 else if (i=600000) bonus=bon4+(i-400000)*0.03。 /利润在40万元至60万时的奖金 else if (i=1000000) bonus=bon6+(i-600000)*0.015。 /利润在60万元至100万时的奖金 else bonus=bon10+(i-1000000)*0.01。 /利润在100万元以上时的奖金 coutbonus=bonusendl。 return 0。 3.13题另一解#include using n

    18、amespace std。int main ()long i。 float bonus,bon1,bon2,bon4,bon6,bon10。 int c。 bon1=100000*0.1。 bon2=bon1+100000*0.075。 bon4=bon2+200000*0.05。 bon6=bon4+200000*0.03。 bon10=bon6+400000*0.015。 couti。 c=i/100000。 if (c10) c=10。 switch(c) case 0: bonus=i*0.1。 break。 case 1: bonus=bon1+(i-100000)*0.075。 b

    19、reak。 case 2: case 3: bonus=bon2+(i-200000)*0.05。break。 case 4: case 5: bonus=bon4+(i-400000)*0.03。break。 case 6: case 7: case 8: case 9: bonus=bon6+(i-600000)*0.015。 break。 case 10: bonus=bon10+(i-1000000)*0.01。 coutbonus=bonusendl。 return 0。3.14题#include using namespace std。int main ()int t,a,b,c,

    20、d。 coutabcd。 couta=a, b=b, c=c,d=db) t=a。a=b。b=t。 if (ac) t=a。 a=c。 c=t。 if (ad) t=a。 a=d。 d=t。 if (bc) t=b。 b=c。 c=t。 if (bd) t=b。 b=d。 d=t。 if (cd) t=c。 c=d。 d=t。 coutthe sorted sequence:endl。 couta, b, c, dendl。 return 0。 3.15题#include using namespace std。int main ()int p,r,n,m,temp。 coutnm。 if (

    21、nm) temp=n。 n=m。 m=temp。 /把大数放在n中, 小数放在m中 p=n*m。 /先将n和m的乘积保存在p中, 以便求最小公倍数时用 while (m!=0) /求n和m的最大公约数 r=n%m。 n=m。 m=r。 coutHCF=nendl。 coutLCD=p/nendl。 / p是原来两个整数的乘积 return 0。 3.16题#include using namespace std。int main ()char c。 int letters=0,space=0,digit=0,other=0。 coutenter one line:=a & c=A & c=0

    22、& c=9) digit+。 else other+。 coutletter:letters, space:space, digit:digit, other:otherendl。 return 0。 3.17题#include using namespace std。int main ()int a,n,i=1,sn=0,tn=0。 coutan。 while (i=n) tn=tn+a。 /赋值后的tn为i个a组成数的值 sn=sn+tn。 /赋值后的sn为多项式前i项之和 a=a*10。 +i。 couta+aa+aaa+.=snendl。 return 0。 3.18题#include

    23、 using namespace std。int main ()float s=0,t=1。 int n。 for (n=1。n=20。n+) t=t*n。 / 求n! s=s+t。 / 将各项累加 cout1!+2!+.+20!=sendl。 return 0。 3.19题#include using namespace std。int main ()int i,j,k,n。 coutnarcissus numbers are:endl。 for (n=100。n1000。n+) i=n/100。 j=n/10-i*10。 k=n%10。 if (n = i*i*i + j*j*j + k*

    24、k*k) coutn 。 coutendl。return 0。 3.20题#include using namespace std。 int main() const int m=1000。 / 定义寻找范围 int k1,k2,k3,k4,k5,k6,k7,k8,k9,k10。 int i,a,n,s。 for (a=2。a=m。a+) / a是21000之间的整数,检查它是否为完数 n=0。 / n用来累计a的因子的个数 s=a。 / s用来存放尚未求出的因子之和,开始时等于a for (i=1。ia。i+) / 检查i是否为a的因子 if (a%i=0) / 如果i是a的因子 n+。 /

    25、 n加1,表示新找到一个因子 s=s-i。 / s减去已找到的因子,s的新值是尚未求出的因子 之和 switch(n) / 将找到的因子赋给k1,.,k10 case 1: k1=i。 break。 / 找出的笫1个因子赋给k1 case 2: k2=i。 break。 / 找出的笫2个因子赋给k2 case 3: k3=i。 break。 / 找出的笫3个因子赋给k3 case 4: k4=i。 break。 / 找出的笫4个因子赋给k4 case 5: k5=i。 break。 / 找出的笫5个因子赋给k5 case 6: k6=i。 break。 / 找出的笫6个因子赋给k6 case

    26、7: k7=i。 break。 / 找出的笫7个因子赋给k7 case 8: k8=i。 break。 / 找出的笫8个因子赋给k8 case 9: k9=i。 break。 / 找出的笫9个因子赋给k9 case 10: k10=i。 break。 / 找出的笫10个因子赋给k10 if (s=0) / s=0表示全部因子都已找到了 couta is a 完数endl。 cout1) coutk1,1表示a至少有2个因子 if (n2) cout,2表示至少有3个因子,故应再输出一个因子 if (n3) cout,3表示至少有4个因子,故应再输出一个因子 if (n4) cout,5) co

    27、ut,6) cout,7)cout,8)cout,9)cout,k10。 coutendlendl。 return 0。 3.20题另一解#include using namespace std。 int main() int m,s,i。 for (m=2。m1000。m+) s=0。 for (i=1。im。i+) if (m%i)=0) s=s+i。 if(s=m) coutm is a完数endl。 coutits factors are:。 for (i=1。im。i+) if (m%i=0) couti 。 coutendl。 return 0。 3.20题另一解#include

    28、using namespace std。int main() int k11。 int i,a,n,s。 for (a=2。a=1000。a+) n=0。 s=a。 for (i=1。ia。i+) if (a%i)=0) n+。 s=s-i。 kn=i。 / 将找到的因子赋给k1k10 if (s=0) couta is a 完数endl。 coutits factors are:。 for (i=1。in。i+) coutki 。 coutknendl。 return 0。 3.21题#include using namespace std。int main() int i,t,n=20。

    29、double a=2,b=1,s=0。 for (i=1。i=n。i+) s=s+a/b。 t=a。 a=a+b。 / 将前一项分子与分母之和作为下一项的分子 b=t。 / 将前一项的分子作为下一项的分母 coutsum=sendl。 return 0。 3.22题#include using namespace std。int main() int day,x1,x2。 day=9。 x2=1。 while(day0) x1=(x2+1)*2。 / 第1天的桃子数是第2天桃子数加1后的2倍 x2=x1。 day-。 couttotal=x1endl。 return 0。 3.23题#incl

    30、ude #include using namespace std。int main() float a,x0,x1。 couta。 / 输入a的值 x0=a/2。 x1=(x0+a/x0)/2。 do x0=x1。 x1=(x0+a/x0)/2。 while(fabs(x0-x1)=1e-5)。 coutThe square root of a is x1endl。 return 0。 3.24题#include using namespace std。int main() int i,k。 for (i=0。i=3。i+) / 输出上面4行*号 for (k=0。k=2*i。k+) cout

    31、*。 / 输出*号 coutendl。 /输出完一行*号后换行 for (i=0。i=2。i+) / 输出下面3行*号 for (k=0。k=4-2*i。k+) cout*。 / 输出*号 coutendl。 / 输出完一行*号后换行 return 0。 3.25题#include using namespace std。int main() char i,j,k。 /* i是a的对手。j是b的对手。k是c的对手*/ for (i=X。i=Z。i+) for (j=X。j=Z。j+) if (i!=j) for (k=X。k=Z。k+) if (i!=k & j!=k) if (i!=X & k!=X & k!=Z) coutA-i B-j C-kendl。 return 0。

    展开阅读全文
    提示  163文库所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。
    关于本文
    本文标题:《c-程序设计方案》谭浩强课后习题答案(DOC 131页).doc
    链接地址:https://www.163wenku.com/p-5853904.html

    Copyright@ 2017-2037 Www.163WenKu.Com  网站版权所有  |  资源地图   
    IPC备案号:蜀ICP备2021032737号  | 川公网安备 51099002000191号


    侵权投诉QQ:3464097650  资料上传QQ:3464097650
       


    【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。

    163文库