c++primerplus(第六版)课后编程练习答案

上传人:每**** 文档编号:65083217 上传时间:2022-03-22 格式:DOC 页数:20 大小:69.50KB
收藏 版权申诉 举报 下载
c++primerplus(第六版)课后编程练习答案_第1页
第1页 / 共20页
c++primerplus(第六版)课后编程练习答案_第2页
第2页 / 共20页
c++primerplus(第六版)课后编程练习答案_第3页
第3页 / 共20页
资源描述:

《c++primerplus(第六版)课后编程练习答案》由会员分享,可在线阅读,更多相关《c++primerplus(第六版)课后编程练习答案(20页珍藏版)》请在装配图网上搜索。

1、第二章:开始学习C+/ex2.1-display your name and address#includeint main(void)using namespace std;coutMy name is liao chunguang and I live in hunan chenzhou.n”;/ex2.2-convert the furlong units to yard uints-把浪单位换位码单位#includedouble fur2yd(double);int main()using namespace std;coutfur;coutconvert the furlong to

2、 yardendl;double yd;yd=fur2yd(fur);coutfur furlong is yd yardendl;return 0;double fur2yd(double t)return 220*t;/ex2.3-每个函数都被调用两次#includevoid mice();void see();using namespace std;int main()mice();mice();see();see();return 0;授课:XXXvoid mice()coutthree blind miceendl;void see()coutsee how they runendl

3、;/ex2.4#includeint main() using namespace std; coutage; int month; month=age*12; coutage years is month monthsendl; return 0;/ex2.5-convert the Celsius valve to Fahrenheit value#includedouble C2F(double);int main()using namespace std;coutC;double F;F=C2F(C);coutC degrees Celsius is F degrees Fahrenh

4、eit.endl;return 0;double C2F(double t)return 1.8*t+32; 授课:XXX/ex2.6-convert the light years valve to astronomical units-把光年转换为天文单位#includedouble convert(double);/函数原型int main()using namespace std;coutlight_years;double astro_units;astro_units=convert(light_years);coutlight_years light_years = astro_

5、units astronomical units.endl;return 0;double convert(double t)return 63240*t;/1 光年=63240 天文单位 /ex2.7-显示用户输入的小时数和分钟数#includevoid show();main()using namespace std;show();return 0;void show()using namespace std;int h,m;couth;coutm;coutTime:h:mendl;授课:XXX第三章:处理数据/ex3.1将身高用英尺(feet)和英寸(inch)表示#includecon

6、st int inch_per_feet=12;/ const常量-1feet=12inches-1英尺=12英寸int main()using namespace std;coutht_inch;int ht_feet=ht_inch/inch_per_feet;/取商int rm_inch=ht_inch%inch_per_feet;/取余coutyour height is ht_feet feet,and rm_inch inchesn;return 0;/ex3.2-计算相应的body mass index(体重指数)#includeconst int inch_per_feet=1

7、2;const double meter_per_inch=0.0254;const double pound_per_kilogram=2.2;int main()using namespace std;coutPlease enter your height:endl;coutht_feet;coutht_inch;coutwt_pound;int inch;inch=ht_feet*inch_per_feet+ht_inch;double ht_meter;ht_meter=inch*meter_per_inch;double wt_kilogram;wt_kilogram=wt_pou

8、nd/pound_per_kilogram;coutendl;coutYour pensonal body information as follows:endl;cout身高:inch(英尺inch)n身高:ht_meter(米meter)n体重:wt_kilogram(千克kilogram)n;授课:XXXdouble BMI;BMI=wt_kilogram/(ht_meter*ht_meter);coutyour Body Mass Index(体重指数) is BMIendl;return 0;/ex3.3 以度,分,秒输入,以度输出#includeconst int minutes_

9、per_degree=60;const int seconds_per_minute=60;int main()using namespace std;coutEnter a latitude in degrees,minutes,and seconds:n;coutdegree;coutminute;coutsecond;double show_in_degree;show_in_degree=(double)degree+(double)minute/minutes_per_degree+(double)second/minutes_per_degree/seconds_per_minut

10、e;coutdegree degrees,minute minutes,secondseconds =show_in_degree degreesn;return 0;/ex3.4#includeconst int hours_per_day=24;const int minutes_per_hour=60;const int seconds_per_minute=60;int main()using namespace std;coutseconds;int Day,Hour,Minute,Second;Day=seconds/seconds_per_minute/minutes_per_h

11、our/hours_per_day;授课:XXXHour=seconds/seconds_per_minute/minutes_per_hour%hours_per_day;Minute=seconds/seconds_per_minute%minutes_per_hour;Second=seconds%seconds_per_minute;coutsecondsseconds = Day days,Hour hours,Minute minutes,Second secondsn;return 0;/ex3.5#includeint main() using namespace std; c

12、outworld_population; coutUS_population; double percentage; percentage=(double)US_population/world_population*100; coutThe population of the US is percentage% of the world population.n; return 0;/ex3.6 汽车耗油量-美国(mpg)or欧洲风格(L/100Km)#includeint main()using namespace std;coutm_distance;coutm_gasoline;cou

13、tYour car can run m_distance/m_gasoline miles per gallonn;coutComputing by European style:n;coutk_distance;coutk_gasoline;coutIn European style:your can used 100*k_gasoline/k_distance liters of petrol per 100 kilometersn;return 0;授课:XXX/ex3.7 automobile gasoline consumption-耗油量-欧洲风格(L/100Km)转换成美国风格(

14、mpg)#includeint main()using namespace std;coutEnter the automobile gasoline consumption figure innEuro_style;coutConverts to U.S. style(miles per gallon):endl;coutEuro_style L/100Km = 62.14*3.875/Euro_style mpgn;return 0;/ Note that 100 kilometers is 62.14 miles, and 1 gallon is 3.875 liters. /Thus,

15、 19 mpg is about 12.4 L/100Km, and 27 mpg is about 8.7 L/100Km.Enter the automobile gasoline consumption figure inEuropean style(liters per 100 kilometers):12.4Converts to U.S. style(miles per gallon):12.4 L/100Km = 19.4187 mpgPress any key to continue/ ex3.7 automobile gasoline consumption-耗油量-美国风格

16、(mpg)转换成欧洲风格(L/100Km)#includeint main()using namespace std;coutEnter the automobile gasoline consumption figure innUS_style;coutConverts to European style(miles per gallon):endl;coutUS_style mpg = 62.14*3.875/US_styleL/100Kmn;return 0;/ Enter the automobile gasoline consumption figure inU.S. style(m

17、iles per gallon):19Converts to European style(miles per gallon):授课:XXX19 mpg = 12.6733L/100KmPress any key to continue第四章 复合类型/ex4.1 display the information of student#includeconst int Asize=20;using namespace std;struct student/定义结构描述char firstnameAsize;char lastnameAsize;char grade;int age;void di

18、splay(student);/函数原型放在结构描述后int main()coutwhat is your first name?endl;student lcg;/创建结构变量(结构数据对象)cin.getline(lcg.firstname,Asize);coutwhat is your last name?endl;cin.getline(lcg.lastname,Asize);coutwhat letter grade do you deserve?lcg.grade;coutwhat is your age?lcg.age;display(lcg);return 0;void dis

19、play(student name)coutName: name.firstname,name.lastnameendl;coutGrade:char(name.grade+1)endl;coutAge:name.ageendl;/ex4.2 use the string-class instead of char-array#include#includeint main()授课:XXXusing namespace std;string name,dessert;coutEnter your name: n;getline(cin,name); coutEnter your favorit

20、e dessert: n;getline(cin,dessert); coutI have some delicious dessert;cout for you, namesbumpc();/修改后的 break; ex4.3 输入其名和姓,并组合显示#include#includeconst int Asize=20;int main()using namespace std;char fnameAsize;char lnameAsize;char fullname2*Asize+1;coutEnter your first name:;/输入名字,存储在fname数组中cin.getli

21、ne(fname,Asize);coutEnter your last name:;/输入姓,存储在lname数组中cin.getline(lname,Asize);strncpy(fullname,lname,Asize);/把姓lname复制到fullname空数组中strcat(fullname, );/把“, ”附加到上述fullname尾部strncat(fullname,fname,Asize);/把fname名字附加到上述fullname尾部fullname2*Asize=0;/为防止字符型数组溢出,在数组结尾添加结束符 coutHeres the information in

22、a single string:fullnameendl;/显示组合结果return 0;/ex4.4 使用string对象 存储、显示组合结果#include#include授课:XXXint main()using namespace std;string fname,lname,attach,fullname;coutEnter your first name:;getline(cin,fname);/note:将一行输入读取到string类对象中使用的是getline(cin,str) /它没有使用句点表示法,所以不是类方法coutEnter your last name:;getli

23、ne(cin,lname);attach=, ;fullname=lname+attach+fname;coutHeres the information in a single string:fullnameendl;return 0;/ex4.5 declare a struct and initialize it 声明结果并创建一个变量#includeconst int Asize=20;struct CandyBarchar brandAsize;double weight;int calory;int main()using namespace std;CandyBar snack=

24、Mocha Munch,2.3,350;coutHeres the information of snack:n;coutbrand:snack.brandendl;coutweight:snack.weightendl;coutcalory:snack.caloryendl;return 0;/ex4.6 结构数组的声明及初始化#includeconst int Asize=20;struct CandyBarchar brandAsize;double weight;授课:XXXint calory;int main()using namespace std;CandyBar snack3

25、=Mocha Munch,2.3,350,XuFuJi,1.1,300,Alps,0.4,100; for(int i=0;i3;i+)/利用for循环来显示snack变量的内容coutsnacki.brandendlsnacki.weightendlsnacki.caloryendlendl;return 0;/ex4.7 pizza披萨饼#include#includeconst int Size=20;struct pizza/声明结构char companySize;double diameter;double weight;int main()using namespace std;

26、pizza pie;/创建一个名为pie的结构变量coutWhats the name of pizza company:;cin.getline(pany,Size);coutpie.diameter;coutpie.weight;coutcompany:panyendl;coutdiameter:pie.diameterinchesendl;coutweight:pie.weightounchesendl;return 0;授课:XXX/ex4.8 pizza pie 披萨饼 使用new创建动态结构#include#includeconst int Size=20;struct pizza

27、/声明结构char companySize;double diameter;double weight;int main()using namespace std;pizza *pie=new pizza;/使用new创建动态结构coutpie-diameter;cin.get();/读取下一个字符coutcompany,Size);coutpie-weight;coutdiameter:diameter inchesendl;coutcompany:companyendl;coutweight:weight ounchesendl;delete pie;/delete释放内存return 0

28、;/ex.4.9 使用new动态分配数组方法1#include#includeusing namespace std;struct CandyBarstring brand;double weight;int calory;int main()授课:XXXCandyBar *snack= new CandyBar3;snack0.brand=A;/单个初始化由new动态分配的内存snack0.weight=1.1;snack0.calory=200;snack1.brand=B;snack1.weight=2.2;snack1.calory=400;snack2.brand=C;snack2.

29、weight=4.4;snack2.calory=500;for(int i=0;i3;i+)cout brand: snacki.brand endl;cout weight: snacki.weight endl;cout calorie: snacki.calory endlendl;delete snack; return 0;/ex.4.10 数组方法1#include int main() using namespace std; const int Size = 3; int successSize; cout success0success1success2; coutsucc

30、ess1:success0endl;coutsuccess2:success1endl;coutsuccess3:success2endl;double average=(success0+success1+success2)/3;coutaverage:averageendl; return 0; /ex.4.10 array方法2#include #include int main()授课:XXX using namespace std;arrayad=0; cout ad0ad1ad2; coutsuccess1:ad0endl;coutsuccess2:ad1endl;coutsucc

31、ess3:ad2endl;ad3=(ad0+ad1+ad2)/3;coutaverage:ad3endl; return 0; 第五章 循环和关系表达式/ex.5.1#include int main() using namespace std; coutnum1num2; int sum=0; for(int temp=num1;temp=num2;+temp)/or temp+ sum+=temp; coutThe sum from num1 to num2 is sumendl; return 0;/ex.5.2#include #includeint main() using name

32、space std;arrayad=0; ad1=ad0=1L;for(int i=2;i101;i+)adi=i*adi-1;授课:XXXfor(int i=0;i101;i+)couti! = adiendl; return 0;/ex.5.3#include int main() using namespace std; coutnum)&num!=0) sum+=num; coutSo far, the sum is sumendl; coutPlease enter an integer: ; return 0;/ex.5.4#include int main() using nam

33、espace std; double sum1,sum2; sum1=sum2=0.0; int year=0; while(sum2=sum1) +year; sum1+=10; sum2=(100+sum2)*0.05+sum2; 授课:XXX cout经过year年后,Cleo的投资价值才能超过Daphne的投资价值。endl; cout此时,Cleo的投资价值为sum1,而Daphne的投资价值为sum2endl; return 0; /ex.5.5#include const int MONTHS = 12;const char* monthsMONTHS=January,Febru

34、ary,March,April,May,June,July,August,September,October,November,December;int main() using namespace std; int salesMONTHS,sum=0; for(int i=0;iMONTHS;i+) cout请输入在monthsisalesi; sum+=salesi; cout这一年中的C+ For Fools的总销售量为:sumendl; return 0;/ex.5.6#include const int MONTHS = 12;const char* monthsMONTHS=Jan

35、uary,February,March,April,May,June,July,August,September,October,November,December;const char* years3=第一年,第二年,第三年;int main() using namespace std; int year_sale3,sum=0,sales3MONTHS; for(int i=0;i3;i+) int temp=0;授课:XXX coutyearsi的每个月销售量:endl; for(int j=0;jMONTHS;j+) cout请输入monthsjsalesij; temp+=sales

36、ij; year_salei=temp; sum+=year_salei; for(int i=0;i3;i+) coutyearsi的销售量为:year_saleiendl; cout这三年的总销售量为:sumendl; return 0; /ex.5.7#include #include using namespace std;struct car string name; int year;int main() coutnum).get(); car* ps=new carnum; for(int i=0;inum;+i) coutCar #i+1:n; coutPlease enter

37、 the make: ; getline(cin,psi.name); coutpsi.year).get(); coutHere is your collection:n; for(int i=0;inum;+i) coutpsi.year psi.nameendl; delete ps;授课:XXX return 0; /ex.5.8#include #include int main() using namespace std; char word20; int sum=0; coutword; while(strcmp(word,done) sum+; cinword; coutYou

38、 entered a total of sum words.n; return 0;/ex.5.9#include #include int main() using namespace std; string word; int sum=0; coutword; while(word!=done) sum+; cinword; coutYou entered a total of sum words.n;授课:XXX return 0;/ex.5.10#include int main() using namespace std; coutnum;for(int i=0;i1;j-) cou

39、t.;for(int k=0;k=i;+k) cout*;coutendl;return 0;欢迎您的光临,Word文档下载后可修改编辑.双击可删除页眉页脚.谢谢!希望您提出您宝贵的意见,你的意见是我进步的动力。赠语; 1、如果我们做与不做都会有人笑,如果做不好与做得好还会有人笑,那么我们索性就做得更好,来给人笑吧! 2、现在你不玩命的学,以后命玩你。3、我不知道年少轻狂,我只知道胜者为王。4、不要做金钱、权利的奴隶;应学会做“金钱、权利”的主人。5、什么时候离光明最近?那就是你觉得黑暗太黑的时候。6、最值得欣赏的风景,是自己奋斗的足迹。7、压力不是有人比你努力,而是那些比你牛几倍的人依然比你努力。 (注:可编辑下载,若有不当之处,请指正,谢谢!) 授课:XXX

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

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!