北语09考试批次《C++》离线作业.docx
《北语09考试批次《C++》离线作业.docx》由会员分享,可在线阅读,更多相关《北语09考试批次《C++》离线作业.docx(6页珍藏版)》请在冰点文库上搜索。
北语09考试批次《C++》离线作业
北语-201609考试批次《C++〉离
线作业
201609考试批次
《C++》结课作业
学生姓名
学号
学习中心
北京语言大学网络教育学院
《C++》结课作业
注意:
本学期所布置的结课作业,请同学一律按照以下要求执行:
1)结课作业提交起止时间:
2016年8月4日一9月12日。
(届时平台自动关闭,逾期不予接收。
)
2)结课作业课程均需通过“离线作业”栏目提交电子版,学院不收取纸介的结课作业,以纸介回寄的作业一律视为无效;
3)截止日期前可多次提交,平台只保留最后一次提交的文档,阅卷时以最后一次提交的结课作业为准,截止日期过后将关闭平台,逾期不交或科目提交错误者,按0分处理;
4)提交文档要求:
提交的文档格式为doc、rar,大小10M以内;
5)必须严格按照每门课程的答题要求完成作业,没有按照学院要求来做的结课作业,将酌情扣分。
一.论述题(本大题共5小题,请任选其中两道题作答,每小题25分,总分50分)
1.C++中的继承使编程者可以用已有的数据类型创建新的数据类型,并保留已有数据类型的特点。
请简述继承方式的三种类型,及三种继承类型的类成员的特点。
答:
(1)公有继承(public)
公有继承的特点是基类的公有成员和保护成员作为派生类的成员时,它们都保持原有的状态,而基类的私有成员仍然是私有的,不能被这个派生类的子类所访问。
(2)私有继承(private)
私有继承的特点是基类的公有成员和保护成员都作为派生类的私有成员,并且不能被这个派生类的子类所访问。
(3)保护继承(protected)
保护继承的特点是基类的所有公有成员和保护成员都成为派生类的保护成员,并且只能被它的派生类成员函数或友元访问,基类的私有成员仍然是私有的。
下面列出三种不同的继承方式的基类特性和派生类特性。
publicprotectedprivate
公有继承publicprotected不可见私有继承privateprivate不可见保护继承protectedprotected不可见
2.请简述C++中引用和指针的区别。
答:
(1)指针是一个实体,而引用仅是个别名;
(2)引用使用时无需解引用(*),指针需要解引用;
(3)引用只能在定义时被初始化一次,之后不可变;指针可变;
引用从一而终”A_A
(4)引用没有const,指针有const,
const的指针不可变;
(5)引用不能为空,指针可以为空;
(6)“sizeof引用”得到的是所指向的变
量(对象)的大小,而“sizeof指针"得到的是指针本身(所指向的变量或对象的地址)的大小;
typeid(T)==typeid(T&)恒为真,sizeof(T)==sizeof(T&)恒为真,但
是当引用作为类成员名称时,其占用空间与指针相同4个字节(没找到标准的规定)。
(7)指针和引用的自增(++)运算意义不一样;
3.面向对象程序设计有哪些优点?
答:
(1)易维护采用面向对象思想设计的结构,可读性高,由于继承的存在,即使改变需求,那么维护也只是在局部模块,所以维护起来是非常方便和较低成本的。
(2)质量高
在设计时,可重用现有的,在以前的项目的领域中已被测试过的类使系统满足业务需求并具有较高的质量。
(3)效率高
在软件开发时,根据设计的需要对现实世界的事物进行抽象,产生类。
使用这样的方法解决问题,接近于日常生活和自然的思考方式,势必提高软件开发的效率和质量。
(4)易扩展
由于继承、封装、多态的特性,自然设计出高内聚、低耦合的系统结构,使得系统更灵活、更容易扩展,而且成本较低。
4.C++编译器自动为类产生的四个缺省函数是什么?
答:
(1)默认构造函数,
(2)拷贝构造函数,
(3)赋值函数,
(4)析构函数。
5•不允许重载的5个运算符是哪些?
答:
(1)*(成员指针访问运算符号)
(2):
:
域运算符
(3)Sizeof长度运算符号
(4)?
:
条件运算符号
(5).(成员访问符)
二.编程题(本大题共5小题,请任选其中两道题作答,每小题25分,总分50分)
1.已知交通工具类定义如下,要求:
(1)实现
这个类;
(2)定义并实现一个小车类car,是
它的公有派生类,小车本身的私有属性有载人
数,小车的函数有init(设置车轮数,重量和载人数),getpassenger(获取载人数),print
(打印车轮数,重量和载人数)
classvehicle
{protected:
intwheels;//车轮数floatweight;//重量public:
voidinit(intwheels,floatweight);intget_wheels();
floatget_weight();
voidprint();
};
wheels,float
voidvehicle:
:
init(int
weight)
{this->wheels=wheels;this->weight=weight;coutvvwheelsvvendl;
}
intvehicle:
:
get_wheels()
{returnwheels;
}
floatvehicle:
:
get_weight()
{returnweight;}
voidvehicle:
:
print()
{coutvv"车轮数:
"v"vvweightvvendl;}
答:
classcar:
publicvehicle
{private:
intpassengers;
public:
voidinit(intwheels,floatweight,intpass);
intgetpassenger();
voidprint();};
voidcar:
:
init(intwheels,floatweight,intpass)
{vehicle:
:
init(wheels,weight);
passengers=pass;}
intcar:
:
getpassenger()
{returnpassengers;}
voidcar:
:
print()
coutvv"可载人数:
"vvpassengersvvendl;
}__
2.使用while、do…while、for三种循环语句分别编写计算从1到30的累加的程序代码。
3.设计函数charcapitalize(char);将小写英文字符变为对应的大写字符。
答:
charcapitalize(charch)
{
if{ch>='a'&&ch<=z'}
returnch-'a'+'A;
elsereturnch;
}
4.请按从小到大的顺序输出个、十、百位数字各不相同的所有三位数,结果写入f2.txt中,一个数一行。
5.编写一个函数,实现对一维数组的二分(折半)查找算法。
如找到,则返回其数组下标,否则返回-1。
(二分查找的思想是:
要查找的数据保存在数组中,并且数据已经排好序(如从小到大递增)。
查找时,每次比较数组中间(用数组下标判断)那个数据,如果相等,则找到;如果小于它,则在数组左半边按照相同的方式查找;如果大于它,则在数组右半边按相同方式查找。