C++上机练习题.doc





《C++上机练习题.doc》由会员分享,可在线阅读,更多相关《C++上机练习题.doc(46页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-dateC+上机练习题第一套第一套请使用VC6打开考生文件夹下的工程proj1,该工程含有一个源程序文件proj1.cpp。其中每个注释/ERROR *found*之后的一行有语句存在错误。请修改这些错误,使程序的输出结果为:1 2 3 4 5 6 7 8 9 10 注意:只需修改注释/ERROR *found*的下一行语句,不要改动程序中的其它内容。/ proj1.cpp#
2、include using namespace std;class MyClass public: MyClass(int len) array = new intlen; arraySize = len; for(int i = 0; i arraySize; i+) arrayi = i+1; MyClass() / ERROR *found* delete array; void Print() const for(int i = 0; i arraySize; i+)/ ERROR *found* cout arrayi ; cout endl; private: int *array
3、; int arraySize;int main()/ ERROR *found* MyClass obj(10); obj.Print(); return 0;请使用VC6打开考生文件夹下的工程proj2,该工程含有一个源程序文件proj2.cpp。其中定义了类Bag和用于测试该类的主函数main。类Bag是一个袋子类,用来存放带有数字标号的小球(如台球中的球,在类中用一个整数值表示一个小球),其中运算符成员函数=用来判断两个袋子对象是否相同(即小球的个数相同,每种小球数目也相同,但与它们的存储顺序无关);成员函数int InBag(int ball)用来返回小球ball在当前袋子内出现的次
4、数,返回0表示该小球不存在。为类实现这两个函数,其用法可参见主函数main。 运算符函数operator =中首先判断两个袋子内的小球个数是否相同,再调用InBag函数来判断每种小球在两个袋子内是否具有相同的出现次数。注意:只需在指定位置编写适当代码,不要改动程序中的其他内容,也不能删除或移动/*found*。/ proj2.cpp#include using namespace std;const int MAXNUM = 100;class Bag private: int num; int bagMAXNUM;public: Bag(int m, int n=0); / 构造函数 boo
5、l operator = (Bag &b);/ 重载运算符= int InBag(int ball);/ 某一小球在袋子内的出现次数,返回0表示不存在;Bag:Bag(int m, int n) if(n MAXNUM) cerr Too many membersn; exit(-1); for(int i = 0; i n; i+) bagi = mi; num = n;bool Bag:operator = (Bag &b)/ 实现运算符函数= if (num != b.num)/ 元素个数不同 return false; for (int i = 0; i num; i+)/*found
6、* if (InBag(bagi)!=b.InBag(bagi)/ TODO: 加入条件, 判断当前袋子中每个元素在当前袋子和袋子b中是否出现次数不同/*found* return false;/ TODO: 加入一条语句 return true;int Bag:InBag(int ball) int count = 0; for (int i = 0; i n; for (i = 0; i datai; Bag b1(data, n);/ 创建袋子对象b1 cin n; for (i = 0; i datai; Bag b2(data, n);/ 创建袋子对象b2 if( b1 = b2)/
7、 测试b1和b2是否相同 cout Bag b1 is same with Bag b2n; else cout Bag b1 is not same with Bag b2n; return 0;请使用VC6打开考生目录下的工程文件proj3。此工程包含一个源程序文件proj3.cpp,其中定义了用于表示二维向量的类MyVector;程序应当显示:(6,8)但程序中有缺失部分,请按下面的提示,把下划线标出的三处缺失部分补充完整: (1)在/*1* *found*的下方是构造函数的定义,它用参数提供的坐标对x和y进行初始化。 (2)在/*2* *found*的下方是减法运算符函数定义中的一条语
8、句。两个二维向量相减生成另一个二维向量:它的X坐标等于两个向量X的坐标之差,它的Y坐标等于两个向量Y坐标之差。 (3)在/*3* *found*的下方的语句的功能是使变量v3获得新值,它等于向量v1与向量v2之和。注意:只需在指定位置编写适当的代码,不要改动程序中的其它内容,也不能删除或移动*found*。/ proj3.cpp#includeusing std:ostream;using std:cout;using std:endl;class MyVector /表示二维向量的类 double x; /X坐标值 double y; /Y坐标值public: MyVector(double
9、 i=0.0 , double j=0.0); /构造函数 MyVector operator+( MyVector j); /重载运算符+ friend MyVector operator-( MyVector i, MyVector j); /重载运算符- friend ostream& operator( ostream& os, MyVector v); /重载运算符;/*1* *found*MyVector:MyVector(double i , double j): x(i),y(j)MyVector MyVector:operator+( MyVector j) return M
10、yVector(x+j.x, y+j.y);MyVector operator-( MyVector i, MyVector j)/*2* *found* return MyVector(i.x-j.x,i.y-j.y);ostream& operator( ostream& os, MyVector v) os ( v.x , v.y ) ; /输出向量v的坐标 return os;int main() MyVector v1(2,3), v2(4,5), v3;/*3* *found* v3=v1+v2; coutv3endl; return 0;第二套请使用VC6打开考生文件夹下的工程p
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- C+ 上机 练习题

限制150内