《C语言程序设计课后习题答案.doc》由会员分享,可在线阅读,更多相关《C语言程序设计课后习题答案.doc(84页珍藏版)》请在三一办公上搜索。
1、C+语言程序设计(清华大学郑莉)课后习题答案第 一 章 概述1-1 简述计算机程序设计语言的发展历程。解: 迄今为止计算机程序设计语言的发展经历了机器语言、汇编语言、高级语言等阶段,C+语言是一种面向对象的编程语言,也属于高级语言。1-2 面向对象的编程语言有哪些特点解: 面向对象的编程语言与以往各种编程语言有根本的不同,它设计的出发点就是为了能更直接的描述客观世界中存在的事物以及它们之间的关系。面向对象的编程语言将客观事物看作具有属性和行为的对象,通过抽象找出同一类对象的共同属性(静态特征)和行为(动态特征),形成类。通过类的继承与多态可以很方便地实现代码重用,大大缩短了软件开发周期,并使得
2、软件风格统一。因此,面向对象的编程语言使程序能够比较直接地反问题域的本来面目,软件开发人员能够利用人类认识事物所采用的一般思维方法来进行软件开发。C+语言是目前应用最广的面向对象的编程语言。1-3 什么是结构化程序设计方法这种方法有哪些优点和缺点解: 结构化程序设计的思路是:自顶向下、逐步求精;其程序结构是按功能划分为若干个基本模块;各模块之间的关系尽可能简单,在功能上相对独立;每一模块内部均是由顺序、选择和循环三种基本结构组成;其模块化实现的具体方法是使用子程序。结构化程序设计由于采用了模块分解与功能抽象,自顶向下、分而治之的方法,从而有效地将一个较复杂的程序系统设计任务分解成许多易于控制和
3、处理的子任务,便于开发和维护。 虽然结构化程序设计方法具有很多的优点,但它仍是一种面向过程的程序设计方法,它把数据和处理数据的过程分离为相互独立的实体。当数据结构改变时,所有相关的处理过程都要进行相应的修改,每一种相对于老问题的新方法都要带来额外的开销,程序的可重用性差。由于图形用户界面的应用,程序运行由顺序运行演变为事件驱动,使得软件使用起来越来越方便,但开发起来却越来越困难,对这种软件的功能很难用过程来描述和实现,使用面向过程的方法来开发和维护都将非常困难。 1-4 什么是对象什么是面向对象方法这种方法有哪些特点解: 从一般意义上讲,对象是现实世界中一个实际存在的事物,它可以是有形的,也可
4、以是无形的。对象是构成世界的一个独立单位,它具有自己的静态特征和动态特征。面向对象方法中的对象,是系统中用来描述客观事物的一个实体,它是用来构成系统的一个基本单位,由一组属性和一组行为构成。面向对象的方法将数据及对数据的操作方法放在一起,作为一个相互依存、不可分离的整体-对象。对同类型对象抽象出其共性,形成类。类中的大多数数据,只能用本类的方法进行处理。类通过一个简单的外部接口,与外界发生关系,对象与对象之间通过消息进行通讯。这样,程序模块间的关系更为简单,程序模块的独立性、数据的安全性就有了良好的保障。通过实现继承与多态性,还可以大大提高程序的可重用性,使得软件的开发和维护都更为方便。面向对
5、象方法所强调的基本原则,就是直接面对客观存在的事物来进行软件开发,将人们在日常生活中习惯的思维方式和表达方式应用在软件开发中,使软件开发从过分专业化的方法、规则和技巧中回到客观世界,回到人们通常的思维。1-5 什么叫做封装解: 封装是面向对象方法的一个重要原则,就是把对象的属性和服务结合成一个独立的系统单位,并尽可能隐蔽对象的内部细节。1-6 面向对象的软件工程包括哪些主要内容解: 面向对象的软件工程是面向对象方法在软件工程领域的全面应用,它包括面向对象的分析(OOA)、面向对象的设计(OOD)、面向对象的编程(OOP)、面向对象的测试(OOT)和面向对象的软件维护(OOSM)等主要内容。1-
6、7 简述计算机内部的信息可分为几类解: 计算机内部的信息可以分成控制信息和数据信息二大类;控制信息可分为指令和控制字两类;数据信息可分为数值信息和非数值信息两类。 1-8 什么叫二进制使用二进制有何优点和缺点解: 二进制是基数为2,每位的权是以2 为底的幂的进制,遵循逢二进一原则,基本符号为0和1。采用二进制码表示信息,有如下几个优点:1.易于物理实现;2.二进制数运算简单;3.机器可靠性高;4.通用性强。其缺点是它表示数的容量较小,表示同一个数,二进制较其他进制需要更多的位数。1-9 请将以下十进制数值转换为二进制和十六进制补码:(1)2 (2)9 (3)93 (4)-32 (5)65535
7、 (6)-1 解: (1) (2)10 = (10)2 = (2)16(2) (9)10 = (1001)2 = (9)16(3) (93)10 = (1011101)2 = (5D)16(4) (-32)10 = ()2 = (E0)16(5) (65535)10 = ( )2 = (FFFF)16(6) (-1)10 = ( )2 = (FFFF)161-10 请将以下数值转换为十进制:(1)(1010)2 (2)()2 (3)(01011111 )2 (4)(7F)16 (5)(2D3E)16 (6)(F10E)16解: (1)(1010)2 = (10)10(2)()2 = (143)
8、10(3)(01011111 )2 = (24515)10(4)(7F)16 = (127)10(5)(2D3E)16 = (11582)10(6)(F10E)16 = (61710)101-11 简要比较原码、反码、补码等几种编码方法。解: 原码:将符号位数字化为 0 或 1,数的绝对值与符号一起编码,即所谓符号绝对值表示的编码。正数的反码和补码与原码表示相同。负数的反码与原码有如下关系:符号位相同(仍用1表示),其余各位取反(0变1,1变0)。补码由该数反码的最末位加1求得。 第 二 章 C+简单程序设计2-1 C+语言有那些主要特点和优点解: C+语言的主要特点表现在两个方面,一是全面兼
9、容C,二是支持面向对象的方法。C+是一个更好的C,它保持了C的简洁、高效、接近汇编语言、具有良好的可读性和可移植性等特点,对C的类型系统进行了改革和扩充,因此C+比C更安全,C+的编译系统能检查出更多的类型错误。 C+语言最重要的特点是支持面向对象。2-2 下列标识符哪些是合法的Program, -page, _lock, test2, 3in1, mail, A_B_C_D解: Program, _lock, test2, A_B_C_D是合法的标识符,其它的不是。2-3 例中每条语句的作用是什么#include void main(void)coutHello!n;coutWelcome
10、to c+!n;解: #include 201 / 42. 201 % 43. 201 / 解: 1 502 13 2-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的值为1002-13 写一条for语句,
11、计数条件为n从100到200,步长为2;然后用while和dowhile语句完成同样的循环。解: for循环:for (int n = 100; n = 200; n += 2); while循环:int x = 100;while (n = 200)n += 2; dowhile循环:int n = 100;don += 2; while(n y)x = y;else n;cout The size of a short int is:t sizeof(short) bytes.n;cout The size of a long int is:t sizeof(long) bytes.n;c
12、out The size of a char is:tt sizeof(char) bytes.n;cout The size of a float is:tt sizeof(float) bytes.n;cout The size 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.The size of a long int is: 4 bytes.The size of a char is: 1
13、bytes.The size of a float is: 4 bytes.The size of a double is: 8 bytes.2-20 打印ASCII码为32127的字符。解: #include int main()for (int i = 32; i128; i+)cout (char) i;return 0;程序运行输出:!#$%G()*+,./09:;ABCDEFGHIJKLMNOP_QRSTUVWXYZabcdefghijklmnopqrstuvwxyzs2-21 运行下面的程序,观察其输出,与你的设想是否相同#include int main()unsigned in
14、t x;unsigned int y = 100;unsigned int 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: 46注意,第二行的输出并非 -50,注意x、y、z的数据类型。2-22 运行下面的程序,观察其输出,体会i+与+i的差别。#include int main()int myAge = 39; n;cout You are: yourAge years o
15、ldn;myAge+; .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 print it again.n;cout I am: myAge years old.n;cout You are: yourAge years oldn;return 0;解: 程序运行输出:I am 39 years oldYou are
16、39 years oldOne year passesI am 40 years oldYou are 40 years oldAnother year passesI am 40 years oldYou are 41 years oldLets print it againI am 41 years oldYou are 41 years old2-23 什么叫常量什么叫变量解: 所谓常量是指在程序运行的整个过程中其值始终不可改变的量,除了用文字表示常量外,也可以为常量命名,这就是符号常量;在程序的执行过程中其值可以变化的量称为变量,变量是需要用名字来标识的。2-24 变量有哪几种存储类型
17、解: 变量有以下几种存储类型:auto存储类型:采用堆栈方式分配内存空间,属于一时性存储,其存储空间可以被若干变量多次覆盖使用; register存储类型:存放在通用寄存器中;extern存储类型:在所有函数和程序段中都可引用;static存储类型:在内存中是以固定地址存放的,在整个程序运行期间都有效。2-25 写出下列表达式的值:1. 2 3 & 6 92. ! ( 4 5) | (6 2解: 1 12 -13 04 02-28 编写一个完整的程序,实现功能:向用户提问现在正在下雨吗,提示用户输入Y或N。若输入为Y,显示现在正在下雨。; 若输入为N,显示现在没有下雨。;否则继续提问现在正在下
18、雨吗解: 源程序:#include #include void main()char flag;while(1)cout 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现在没有下雨。或:现在正在下雨吗(Yes or No):y现在正在下雨。2-29 编写一个完整的程序,运行时向用户提问你考试考
19、了多少分(0100),接收输入后判断其等级,显示出来。规则如下:解: #include void main()int i,score;cout score;if (score100 | score0)cout 分数值必须在0到100之间!;elsei = score/10;switch (i)case 10:case 9:cout 你的成绩为优!;break;case 8:cout 你的成绩为良!;break;case 7:case 6:cout 你的成绩为中!;break;default:cout 你的成绩为差!; 程序运行输出:你考试考了多少分(0100):85你的成绩为良!2-30 (1
20、)实现一个简单的菜单程序,运行时显示Menu: A(dd) D(elete) S(ort) Q(uit), Select one:提示用户输入,A表示增加,D表示删除,S表示排序,Q表示退出,输入为A、D、S时分别提示数据已经增加、删除、排序。输入为Q时程序结束。要求使用if else语句进行判断,用break、continue控制程序流程。解: #include #include void main()char choice,c;while(1)cout c;choice = toupper(c);if (choice = A)cout 数据已经增加. endl;continue;else
21、if (choice = D)cout 数据已经删除. endl;continue;else if (choice = S)cout 数据已经排序. endl;continue;else if (choice = Q)break;程序运行输出:Menu: A(dd) D(elete) S(ort) Q(uit), Select one:a数据已经增加. Menu: A(dd) D(elete) S(ort) Q(uit), Select one:d数据已经删除. Menu: A(dd) D(elete) S(ort) Q(uit), Select one:s数据已经排序. Menu: A(dd
22、) D(elete) S(ort) Q(uit), Select one:q (2)实现一个简单的菜单程序,运行时显示Menu: A(dd) D(elete) S(ort) Q(uit), Select one:提示用户输入,A表示增加,D表示删除,S表示排序,Q表示退出,输入为A、D、S时分别提示数据已经增加、删除、排序。输入为Q时程序结束。要求使用Switch语句。解: 源程序:#include #include void main()char choice;while(1)cout choice;switch(toupper(choice)case A:cout 数据已经增加. endl
23、;break;case D:cout 数据已经删除. endl;break;case S:cout 数据已经排序. endl;break;case Q:exit(0);break;default:;程序运行输出:Menu: A(dd) D(elete) S(ort) Q(uit), Select one:a数据已经增加. Menu: A(dd) D(elete) S(ort) Q(uit), Select one:d数据已经删除. Menu: A(dd) D(elete) S(ort) Q(uit), Select one:s数据已经排序. Menu: A(dd) D(elete) S(ort
24、) Q(uit), Select one:q2-31 用穷举法找出1100间的质数,显示出来。分别使用while,do-while,for循环语句实现。解: 源程序: 使用while循环语句:#include #include void main()int i,j,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 是质数. endl;i+; 使用dowhile循环语句:#include #include void main
25、()int i,j,k,flag;i = 2;doflag = 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); 使用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)cou
26、t i 是质数. one;cout two;answer = Divider(one, two);if (answer -1)cout Answer: answer;elsecout Error, cant divide by zero!;return 0;程序运行输出:Enter two numbers.Number one:8Number two:2Answer: 43-8 编写函数把华氏温度转换为摄氏温度,公式为:C = (F - 32) * 5/9; 在主程序中提示用户输入一个华氏温度,转化后输出相应的摄氏温度。解: 源程序见实验指导部分实验三3-9 编写函数判断一个数是否是质数,在主
27、程序中实现输入、输出。解: #include #include int prime(int i); endl;elsecout i 不是质数. endl;int prime(int i)int j,k,flag;flag = 1;k = sqrt(i);for (j = 2; j = k; j+)if(i%j = 0)flag = 0;break;if (flag)return 1;elsereturn 0;程序运行输出:请输入一个整数:11511151是质数.3-10 编写函数求两个整数的最大公约数和最小公倍数。解: 源程序:#include #include int fn1(int i,i
28、nt j); n;(7);(20);cout Now Jack is ;cout () years old and;cout () pounds weight.;return 0;程序运行输出:Jack is a Dog who is 2 years old and 10 pounds weight.Now Jack is 7 years old 20 pounds weight.4-9 设计并测试一个名为Rectangle的矩形类,其属性为矩形的左下角与右上角两个点的坐标,能计算矩形的面积。解: 源程序:#include class Rectanglepublic:Rectangle (in
29、t top, int left, int bottom, int right);Rectangle () int GetTop() const return itsTop; int GetLeft() const return itsLeft; int GetBottom() const return itsBottom; int GetRight() const return itsRight; void SetTop(int top) itsTop = top; void SetLeft (int left) itsLeft = left; void SetBottom (int bott
30、om) itsBottom = bottom; void SetRight (int right) itsRight = right; int GetArea() const;private:int itsTop;int itsLeft;int itsBottom;int itsRight;Rectangle:Rectangle(int top, int left, int bottom, int right)itsTop = top;itsLeft = left;itsBottom = bottom;itsRight = right;int Rectangle:GetArea() const
31、int Width = itsRight-itsLeft;int Height = itsTop - itsBottom;return (Width * Height);int main()Rectangle MyRectangle (100, 20, 50, 80 );int Area = ();cout Area: Area n;return 0;程序运行输出:Area: 3000Upper Left X Coordinate: 204-10 设计一个用于人事管理的People(人员)类。考虑到通用性,这里只抽象出所有类型人员都具有的属性:number(编号)、sex(性别)、birthd
32、ay(出生日期)、id(身份证号)等等。其中出生日期定义为一个日期类内嵌子对象。用成员函数实现对人员信息的录入和显示。要求包括:构造函数和析构函数、拷贝构造函数、内联成员函数、带缺省形参值的成员函数、聚集。解: 本题用作实验四的选做题,因此不给出答案。4-11 定义一个矩形类,有长、宽两个属性,有成员函数计算矩形的面积 解: #include class Rectanglepublic:Rectangle(float len, float width)Length = len;Width = width;Rectangle();float GetArea() return Length * W
33、idth; float GetLength() return Length; float GetWidth() return Width; private:float Length;float Width;void main()float length, width;cout length;cout width;Rectangle r(length, width);cout 长为 length 宽为 width 的矩形的面积为: () endl;程序运行输出:请输入矩形的长度:5请输入矩形的宽度:4长为5宽为4的矩形的面积为:204-12 定义一个数据类型 datatype类,能处理包含字符型
34、、整型、浮点型三种类型的数据,给出其构造函数。解: #include class datatypeenumcharacter,integer,floating_point vartype;union char c;int i;float f;public:datatype(char ch) vartype = character;c = ch;datatype(int ii) vartype = integer;i = ii;datatype(float ff) vartype = floating_point;f = ff;void print();void datatype:print()
35、 switch (vartype) case character:cout 字符型: c endl;break;case integer:cout 整型: i endl;break;case floating_point:cout 浮点型: f endl;break;void main() datatype A(c), B(12), C;();();();程序运行输出:字符型: c整型: 12浮点型: 4-13 定义一个Circle类,有数据成员半径Radius,成员函数GetArea(),计算圆的面积,构造一个Circle的对象进行测试。解: #include class Circlepub
36、lic:Circle(float radius) Radius = radius;Circle()float GetArea() return * Radius * Radius; private:float Radius;void main()float radius;cout radius;Circle p(radius);cout 半径为 radius 的圆的面积为: () endl;程序运行输出:请输入圆的半径:5半径为5的圆的面积为:4-14 定义一个tree类,有成员ages,成员函数grow(int years)对ages加上years,age()显示tree对象的ages的值。解: #include class Tree int ages;public:Tree(int n=0);Tree();void grow(int years);void age();Tree:Tree(int n) ages = n;T