c++语言程序设计(第三版)课后答案.docx

上传人:文*** 文档编号:68352807 上传时间:2022-12-27 格式:DOCX 页数:167 大小:221.61KB
返回 下载 相关 举报
c++语言程序设计(第三版)课后答案.docx_第1页
第1页 / 共167页
c++语言程序设计(第三版)课后答案.docx_第2页
第2页 / 共167页
点击查看更多>>
资源描述

《c++语言程序设计(第三版)课后答案.docx》由会员分享,可在线阅读,更多相关《c++语言程序设计(第三版)课后答案.docx(167页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、第一章概述1-1简述计算机程序设计语言的发展历程。解:迄今为止计算机程序设计语言的发展经历了机器语言、汇编语言、高级语言等阶段,C+语言 是种面向对象的编程语言,也属于高级语言。1-2面向对象的编程语言有哪些特点?解:面向对象的编程语言与以往各种编程语言有根本的不同,它设计的出发点就是为了能更直接 的描述客观世界中存在的事物以及它们之间的关系。面向对象的编程语言将客观事物看作具 有属性和行为的对象,通过抽象找出同一类对象的共同属性(静态特征)和行为(动态特征), 形成类。通过类的继承与多态可以很方便地实现代码重用,大大缩短了软件开发周期,并使 得软件风格统。因此,面向对象的编程语言使程序能够比

2、较直接地反问题域的本来面目, 软件开发人员能够利用人类认识事物所采用的一般思维方法来进行软件开发。C+语言是目前 应用最广的面向对象的编程语言。1-3什么是结构化程序设计方法?这种方法仃哪些优点和缺点?解:结构化程序设计的思路是:自顶向下、逐步求精;其程序结构是按功能划分为若干个基本模 块;各模块之间的关系尽可能简单,在功能上相对独立;每一模块内部均是由顺序、选择和 循环三种基本结构组成;其模块化实现的具体方法是使用子程序。结构化程序设计由于采用 了模块分解与功能抽象,自顶向下、分而治之的方法,从而有效地将一个较复杂的程序系统 设计任务分解成许多易于控制和处理的子任务,便于开发和维护。虽然结构

3、化程序设计方法具有很多的优点,但它仍是一种面向过程的程序设计方法,它把数 据和处理数据的过程分离为相互独立的实体。当数据结构改变时,所有相关的处理过程都要 进行相应的修改,每种相对于老问题的新方法都要带来额外的开销,程序的可重用性差。 由于图形用户界面的应用,程序运行由顺序运行演变为事件驱动,使得软件使用起来越来越 方便,但开发起来却越来越困难,对这种软件的功能很难用过程来描述和实现,使用面向过 程的方法来开发和维护都将非常困难。1-4什么是对象?什么是面向对象方法?这种方法有哪些特点?解:从一般意义上讲,对象是现实世界中一个实际存在的事物,它可以是有形的,也可以是无形 的。对象是构成世界的一

4、个独立单位,它具有自己的静态特征和动态特征。面向对象方法中 的对象,是系统中用来描述客观事物的个实体,它是用来构成系统的一个基本单位,由 组属性和一组行为构成。面向对象的方法将数据及对数据的操作方法放在起,作为个相互依存、不可分离的整体 对象。对同类型对象抽象出其共性,形成类。类中的大多数数据,只能用本类的方法进行 处理。类通过个简单的外部接口,与外界发生关系,对象与对象之间通过消息进行通讯。 这样,程序模块间的关系更为简单,程序模块的独立性、数据的安全性就有了良好的保障。 通过实现继承与多态性,还可以大大提高程序的可重用性,使得软件的开发和维护都更为方 便。面向对象方法所强调的基本原则,就是

5、直接面对客观存在的事物来进行软件开发,将人们在 F)常生活中习惯的思维方式和表达方式应用在软件开发中,使软件开发从过分专业化的方法、 规则和技巧中回到客观世界,回到人们通常的思维。1-5什么叫做封装?解:封装是面向对象方法的一个重要原则,就是把对象的属性和服务结合成一个独立的系统单位, 并尽可能隐蔽对象的内部细节。1-6面向对象的软件工程包括哪些主耍内容?解:面向对象的软件工程是面向对象方法在软件工程领域的全面应用,它包括面向对象的分析 (00A)、面向对象的设计(00D)、面向对象的编程(OOP)、面向对象的测试(00T)和面向对 象的软件维护(OOSM)等主要内容。1-7简述计算机内部的信

6、息可分为几类?解:计算机内部的信息可以分成控制信息和数据信息二大类;控制信息可分为指令和控制字两类; 数据信息可分为数值信息和非数值信息两类。1-8什么叫二进制?使用二进制有何优点和缺点?解:二进制是基数为2,每位的权是以2为底的基的进制,遵循逢二进一原则,基本符号为和 1采用二进制码表示信息,有如下几个优点:1.易于物理实现;2.二进制数运算简单;3. 机器可靠性高;4.通用性强。其缺点是它表示数的容量较小,表示同一个数,二进制较其他 进制需要更多的位数。1-9请将以下十进制数值转换为二进制和十六进制补码:(1) 2 (2) 9 (3) 93(4) -32 (5) 65535 (6) -1解

7、:(1) (2) 10 = (10) 2 = (2) 16(2) (9) 10 = (1001) 2 = (9) 16(3) (93) 10 = (1011101) 2 = (5D) 16(4) (-32) 10 = (11100000) 2 = (E0) 16(5) (65535) 10 = (11111111 11111111) 2 = (FFFF) 16(6) (-1) 10 = (11111111 11111111) 2 = (FFFF) 161-10请将以下数值转换为十进制:(1) (1010) 2 (2) (10001111) 2 (3) (01011111 11000011) 2

8、(4) (7F) 16 (5) (2D3E) 16 (6) (F10E) 16解:(1) (1010) 2 = (10) 10(2) (10001111) 2 = (143) 10(3) (01011111 11000011) 2 = (24515) 10(4) (7F) 16 = (127) 10(5) (2D3E) 16 = (11582) 10(6) (F10E) 16 = (61710) 101-11简要比较原码、反码、补码等儿种编码方法。解:原码:将符号位数字化为或1,数的绝対值与符号起编码,即所谓”符号绝对值表 示”的编码。正数的反码和补码与原码表示相同。负数的反码与原码有如下关系

9、:符号位相同(仍用1表示),其余各位取反(0变1, 1变)。补码由该数反码的最末位加1求得。第二章C+简单程序设计2-1 C+语言有那些主要特点和优点?解:C+语言的主要特点表现在两个方面,一是全面兼容C.二是支持面向对象的方法。C+是 个更好的3它保持了 C的简洁、高效、接近汇编语言、具有良好的可读性和可移植性等特 点,对C的类型系统进行了改革和扩充,因此C+比C更安全,C+的编译系统能检查出更多 的类型错误。C+语言最重要的特点是支持面向对象。2-2下列标识符哪些是合法的?Program, -page, _lock, test2, 3inl, mail, A_B_C_D解:Program,

10、 _lock, test2, A_B_C_D是合法的标识符,其它的不是。2-3例2. 1中每条语句的作用是什么?#include void main (void) (coutHello!n”;coutWelcome to c+!n;解:include 指示编译器将文件iostream, h中的代码嵌入到该程序中该指令所在的地方void main() 主函数名,void表示函数没有返回值函数体标志coutHello!n; 输出字符串Hello!到标准输出设备(显示器)上。 coutWelcome to c+!n: 输出字符串 Welcome to c+!在屏幕输出如下:Hello!Welcome

11、 to c+!2-4使用关键字const而不是#def ine语句的好处有哪些?解:const定义的常量是有类型的,所以在使用它们时编译器可以查错;而且,这些变量在调试 时仍然是可见的。2-5请写出C+语句声明一个常量PI,值为3. 1416i再声明一个浮点型变量a,把PI的值赋 给a。解:const float PI = 3.1416; float a = PI;2-6在下面的枚举类型中,Blue的值是多少?enum COLOR WHITE, BLACK = 100, RED, BLUE, GREEN = 300 ;解:Blue = 1022-7注释行什么作用? C+中有哪几种注释的方法?他

12、们之间佇什么区别?解:注释在程序中的作用是对程序进行注解和说明,以便于阅读。编译系统在对源程序进行编译 时不理会注释部分,因此注释对于程序的功能实现不起任何作用。而且由于编译时忽略注释 部分,所以注释内容不会增加最终产生的可执行程序的大小。适当地使用注释,能够提高程 序的可读性。在C+中,有两种给出注释的方法:种是延用C语言方法,使用/*和*/ 括起注释文字。另种方法是使用,从开始,直到它所在行的行尾,所有字符都被 作为注释处理。2-8什么叫做表达式? x = 5 + 7是一个表达式吗?它的值是多少?解:任何个用于计算值的公式都可称为表达式。x = 5 + 7是一个表达式,它的值为12。2-9

13、下列表达式的值是多少?1. 201/42. 201%43. 201/4.0解:1. 502. 13. 50.252-10执行完下列语句后,a、b、c三个变量的值为多少?a = 30;b = a+;c = +a;解:a: 32 ; b: 30 ; c: 32;2-11在个for循环中,可以初始化多个变量吗?如何实现?解:在for循环设置条件的第一个;前,用,分隔不同的赋值表达式。例如:for (x = 0, y = 10; x 100; x+, y+)2-12执行完下列语句后,n的值为多少?int n;for (n = 0; n 100; n+)解:n的值为!002-13写一条for语句,计数条

14、件为n从100至U200,步长为2;然后用while和dwhile 语句完成同样的循环。解: for循环:for (int n = 100; n = 200; n += 2);while循环: int x = 100;while (n = 200) n += 2;dwhile循环: int n = 100;do (n += 2; while(n y) x = y;else / y x | y = x y = x;2-17修改下面这个程序中的错误,改正后它的运行结果是什么?#include void main() int i int j;i = 10; /给i赋值j = 20; / 给 j 赋值

15、 /cout i + j = i + j; / 输出结果 / return 0;解: 改正: ttinclude int main() ( int i;int j;i = 10; 给i赋值j = 20; / 给 j 赋值 /cout i + j = i + j; /输出结果 / return 0;程序运行输出:i + j = 302-18编写个程序,运行时提示输入个数字,再把这个数字显示出来。解:源程序:#include int main() ( int i;cout 请输入个数字:; cin i;cout 您输入个数字是 i endl; return 0;程序运行输出: 请输入个数字:5 您

16、输入个数字是52-19 C+有哪几种数据类型?简述其值域。编程显示你使用的计算机中的各种数据类型的字 节数。解:源程序:#include using namespace std;int main()cout The size of an int is:tt sizeof(int) bytes. n;cout Thesize of a short int is:t sizeof (short) bytes. n;cout The size of a long int is:t sizeof(long) bytes. n;cout Thesize of a char is:tt sizeof(ch

17、ar) bytes. n;cout Thesize of a float is:tt sizeof(float) bytes. n*;cout Thesize of a double is:t sizeof(double) bytes. n;return 0;程序运行输出:The size of an int is: 4 bytes.The size of a short int is: 2 bytes.Thesize of a long int is: 4 bytes.Thesize of a char is:1 bytes.Thesize of a float is:4 bytes.The

18、 size ofdouble is: 8 bytes.2-20打印ASCII码为32127的字符。解:#include int main()(for (int i = 32; i128; i+)cout (char) i;return 0;程序运行输出:!()*+,/0123456789:;)?ABCDEFGHIJKLMNOP_QRSTUVWXYZ;T abcdefghijklmnopq rstuvwxyzs2-21运行下面的程序,观察其输出,与你的设想是否相同?#include int main() unsigned int x;unsigned int y = 100;unsigned i

19、nt z = 50;x= y - z; cout Difference is: x;x = z - y;cout nNow difference is: x endl;return 0;解:程序运行输出:Difference is: 50Now difference is: 4294967246注意,第二行的输出并非50,注意x、y、z的数据类型。2-22运行下面的程序,观察其输出,体会i+与+i的差别。#include int main() (int myAge = 39; / initialize two integersint yourAge = 39;cout I am: myAge

20、years old. n”;cout You are: yourAge ” years oldn”;myAge+; / postfix increment+yourAge; / prefix incrementcout One year passes. n*;cout I am: myAge “ years old.n”;cout You are: yourAge years oldn;cout Another year passesn;cout I am: myAge+ years old.n;cout You are: “ +yourAge ” years oldn”;cout Lets

21、print it again. n ;cout ! am: myAge years old.n*;cout You are: yourAge years oldn; return 0;解:程序运行输出:I am 39 years oldYou are 39 years oldOne year passesI am 40 years oldYou are 40 years oldAnother year passesI am 40 years oldYou are 41 years oldLet,s print it againI am 41 years oldYou are 41 years

22、old2-23什么叫常量?什么叫变量?解:所谓常量是指在程序运行的整个过程中其值始终不可改变的量,除了用文字表示常量外,也 可以为常量命名,这就是符号常量:在程序的执行过程中其值可以变化的量称为变量,变量 是需耍用名字来标识的。2-24变量有哪几种存储类型?解:变量有以下几种存储类型:auto存储类型:采用堆栈方式分配内存空间,属于一时性存储,其存储空间可以被若干变量 多次覆盖使用:register存储类型:存放在通用寄存器中;extern存储类型:在所有函数和程序段中都可引用:static存储类型:在内存屮是以固定地址存放的,在整个程序运行期间都有效。2-25写出下列表达式的值:1. 2 3

23、 & 6 92. ! ( 4 5) | | (6 2 )解:1. true2. false3. true2-26若a=l, b = 2, c = 3下列各式的结果是什么?1. a b - c2. a b &. -c3. a & b I c4. a b & c解:1. -12. 13. 34. 32-27若a = 1,下列各式的结果是什么?1. ! a | a2. a I a3. a a4. a 2解:1. 12. -13. 04. 02-28编写个完整的程序,实现功能:向用户提问现在正在下雨吗? 提示用户输入Y 或N。若输入为Y,显示”现在正在下雨。”;若输入为N,显示现在没有下雨。;否则继

24、续提问现在正在下雨吗? 解:源程序:#include #include void main()(char flag;while(l)(cout “现在正在下雨吗? (Yes or No):;cin flag;if ( toupper(flag) = Y)(cout ”现在正在下雨。*;break;if ( toupper (flag) = N)(cout 现在没有下雨。”;break;程序运行输出:现在正在下雨吗? (Yes or No) :x 现在正在下雨吗? (Yes or No):l 现在正在下雨吗? (Yes or No) :q 现在正在下雨吗? (Yes or No) :n 现在没有

25、下雨。或:现在正在下雨吗? (Yes or No):y 现在正在下雨。2-29编写个完整的程序,运行时向用户提问你考试考了多少分?(0“100) 接收输入 后判断其等级,显示出来。规则如下:解:#include void main() int i, score;cout 你考试考了多少分?(0100):; cin score;if (score100 | score0)cout 分数值必须在。到100之间!”; else i = score/10;switch (i)(case 10:case 9:cout 你的成绩为优!;break;case 8:cout 你的成绩为良!;break;cas

26、e 7:case 6:cout ”你的成绩为中!”;break;default:cout 你的成绩为差!;程序运行输出:你考试考了多少分?(0100): 85你的成绩为良!2-30 (1)实现个简单的菜单程序,运行时显示Menu; A(dd) D(elete) S(ort) Q(uit), Select one:提示用户输入,A表示增加,D表示删除,S表示排序,Q表示退出,输入为A、 D、S时分别提示数据已经增加、删除、排序。输入为Q时程序结束。要求使用ifelse 语句进行判断,用break、continue控制程序流程。解:#include ttinclude void main()cha

27、r choice, c; while(l)cout Menu: A(dd) D(elete) S(ort) Q(uit),Select one:cin c;choice = toupper(c);if (choice = A)(cout 数据已经增加.” continue;else if (choice = D)(cout ”数据已经删除.” continue;else if (choice = S)(cout ”数据已经排序.” continue;else if (choice = Q) break;程序运行输出:Menu: A(dd) D(elete) S(ort) 数据已经增加.Menu

28、: A(dd) D(elete) S(ort) 数据已经删除.Menu: A(dd) D(elete) S(ort) 数据已经排序.Menu: A(dd) D(elete) S(ort)endl;endl;endl;Q(uit), Select one:aQ(uit), Select one:dQ(uit), Select one:sQ(uit), Select one:q(2)实现个简单的菜单程序,运行时显示Menu: A(dd) D(elete) S(ort) Q(uit), Select one:提示用户输入,A表示增加,D表示删除,S表示排序,Q表示退出,输入为A、D、S 时分别提示“

29、数据已经增加、删除、排序。”输入为Q时程序结束。要求使用Switch语句。 解:源程序:#include ttinclude void main() char choice; while(l) (cout Menu: A(dd) D(elete) S(ort) Q(uit), Select one: cin choice;switch (toupper(choice) (case A:cout 数据已经增加. endl;break;case D:cout 数据已经删除, endl;break;case S:cout 数据已经排序. Sinclude void mainO ( int i, j,

30、 k, flag; i = 2;while(i = 100) ( flag = 1;k = sqrt(i);j = 2;while (j = k) (if(i%j = 0) ( flag = 0;break; j+; ) if (flag) cout i 是质数.叫 include void main()(int i, j, k, flag;i = 2;do flag = 1;k = sqrt (i);j = 2;doif(i%j = 0) flag = 0; break;j+;while (j = k);if (flag)cout i 是质数. endl; i+;while(i = 100)

31、;使用for循环语句:#include #include void main ()(int i, j, k, flag;for(i = 2; i = 100; i+)(flag = 1;k = sqrt(i);for (j = 2; j = k; j+)(if(i%j = 0)(flag = 0;break;)if (flag)cout i ”是质数. endl;程序运行输出:2是质数.3是质数.5是质数.7是质数.11是质数.13是质数.17是质数.19是质数.23是质数.29是质数.31是质数.3?是质数.4I是质数.43是质数.4?是质数.53是质数.59是质数.61是质数.67是质数.

32、71是质数.73是质数.79是质数.83是质数.89是质数.97是质数.2-32比较Break语句与Continue语句的不同用法。解:Break使程序从循环体和switch语句内跳出,继续执行逻辑上的一条语句,不能用在别处;continue语句结朿本次循环,接着开始判断决定是否继续执行下一次循环;2-33定义个表示时间的结构体,可以精确表示年、月、日、小时、分、秒;提示用户输入 年、月、日、小时、分、秒的值,然后完整地显示出来。解:源程序见实验指导”部分实验二2-34在程序中定义个整型变量,赋以rioo的值,要求用户猜这个数,比较两个数的大小, 把结果提示给用户,直到猜对为止。分别使用whi

33、le、dwhile语句实现循环。解:/使用while语句Sinclude void main () int n = 18;int m = 0;while(m != n) cout ”请猜这个数的值为多少? (0)00): cin m;if (n m)cout “你猜的值太小了!” endl;else if (n m)cout 你猜的值太大了!” endl;elsecout 你猜对了! endl;使用dwhile语句#include void main() int n = 18;int m = 0;do cout 请猜这个数的值为多少? (0100): cin m;if (n m)cout 你猜

34、的值太小了! endl;else if (n m)cout 你猜的值太大了! endl;elsecout 你猜对了! endl;while(n != m);程序运行输出:请猜这个数的值为多少? (0100):50你猜的值太大了!请猜这个数的值为多少? (0100):25 你猜的值太大了!请猜这个数的值为多少? (0100):10你猜的值太小了!请猜这个数的值为多少?(0100): 15你猜的值太小了!请猜这个数的值为多少? (0100):18你猜对了!2-35定义枚举类型weekday,例舌Sunday到Saturday七个元素在程序中定义weekday类型 的变量,对其赋值,定义整型变量,看

35、看能否对其赋weekday类型的值。解:include enum weekday (Sunday,Monday,Tuesday,Wednesday,Thursday,Friday, Saturday );void main() ( int i;weekday d = Thursday; cout d = d endl; i = d;cout i = i endl;d = (weekday)6;cout d = d endl; d 二 weekday( 4 );cout “d = d endl; )程序运行输出:d = 4i = 4d = 6d = 4第三章函数3-1 C+中的函数是什么?什么叫

36、主调函数,什么叫被调函数,二者之间有什么关系?如何调 用一个函数?解:一个较为复杂的系统往往需要划分为若干子系统,高级语言中的子程序就是用来实现这种模 块划分的。C和C+语言中的子程序就体现为函数。调用其它函数的函数被称为主调函数,被 其它函数调用的函数称为被调函数。个函数很可能既调用别的函数又被另外的函数调用, 这样它可能在某个调用与被调用关系中充当主调函数,而在另个调用与被调用关系中充 当被调函数。调用函数之前先要声明函数原型。按如下形式声明:类型标识符被调函数名(含类型说明的形参表);声明了函数原型之后,便可以按如下形式调用子函数: 函数名(实参列表)3-2观察下面程序的运行输出,与你设

37、想的有何不同?仔细体会引用的用法。源程序:ttinclude int main()(int intOne;int ArSomeRef = intOne;intOne = 5;cout intOne:tt intOne endl;cout ”rSomeRef:t rSomeRef endl;int intTwo = 8;rSomeRef = intTwo; / not what you think!cout ”nintOne:tt intOne endl;cout ”intTwo;tt intTwo endl;cout rSomeRef:t rSomeRef endl;return 0;程序运行

38、输出:intOne: 5rSomeRef: 5 intOne: 8intTwo: 8rSomeRef: 8 3-3比较值调用和引用调用的相同点与不同点。解:值调用是指当发生函数调用时,给形参分配内存空间,并用实参来初始化形参(直接将实参 的值传递给形参)。这过程是参数值的单向传递过程,一旦形参获得了值便与实参脱离关系, 此后无论形参发生了怎样的改变,都不会影响到实参。引用调用将引用作为形参,在执行主调函数中的调用语句时,系统自动用实参来初始化形参。 这样形参就成为实参的个别名,对形参的任何操作也就直接作用于实参。3-4什么叫内联函数?它有哪些特点?解:定义时使用关键字inline的函数叫做内联

39、函数;编译器在编译时在调用处用函数体进行替换,节省了参数传递、控制转移等开销;内联函数体内不能有循环语句和switch语句;内联函数的定义必须出现在内联函数第一次被调用之前;对内联函数不能进行异常接口声明:3-5函数原型中的参数名与函数定义中的参数名以及函数调用中的参数名必须一致吗?解:不必致,所有的参数是根据位置和类型而不是名字来区分的。3-6重载函数时通过什么来区分?解:重载的函数的函数名是相同的,但它们的参数的个数和数据类型不同,编译器根据实参和形 参的类型及个数的最佳匹配,自动确定调用哪个函数。3-7编写函数,参数为两个unsigned short int型数,返回值为第一个参数除以第二个参数 的结果,数据类型为short int;如果第二个参数为,则返回偵为1。在主程序中实现输入 输出。解:源程序:include short int Divider(unsigned short int a, unsigned short int b) if (b = 0) return -1;else return a/b; typedef unsigned

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

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

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁