第九周 【项目4-我的向量类】
来源:互联网 发布:陌陌用什么软件定位 编辑:程序博客网 时间:2024/05/18 00:46
建立一个向量类MyVector,声明如下,请完成类的定义
[cpp] view plaincopyprint?在CODE上查看代码片派生到我的代码片
class MyVector //定义向量类
{
public:
MyVector(int m); //构造函数,共有m个元素的向量,元素值预置为0
MyVector(const MyVector &v); //复制构造函数
~MyVector(); //析构函数:释放动态数组所占用的存储空间
friend istream &operator>>(istream &input, MyVector &d);
friend ostream &operator<<(ostream &output, const MyVector &d);
friend MyVector operator+(const MyVector &d1,const MyVector &d2);//向量相加,对应位置上的元素相加
friend MyVector operator-(const MyVector &d1,const MyVector &d2);//向量相减,对应位置上的元素相减
bool operator==(const MyVector &d);//判断两个矩阵是否相等,即对应位置上的所有元素是否相等
private:
int *Array; //Array为动态数组指针,指向向量占用内存的起始地址
int num; //向量中元素个数
};
int main()
{
MyVector d1(5),d2(5);
cout<<"输入d1——";
cin>>d1;
cout<<"输入d2——";
cin>>d2;
cout<<"d1="<<d1<<endl;
cout<<"d2="<<d2<<endl;
cout<<"d1+d2="<<d1+d2<<endl;
cout<<"d1-d2="<<d1-d2<<endl;
cout<<"d1"<<((d1==d2)?"==":"!=")<<"d2"<<endl;
return 0;
}
[参考解答]
#include <iostream>using namespace std;class MyVector //定义向量类{public: MyVector(int m);//构造函数,共有m个元素的向量,元素值预置为0 MyVector(const MyVector &v); //复制构造函数 ~MyVector(); //析构函数:释放动态数组所占用的存储空间 friend istream &operator>>(istream &input, MyVector &d); friend ostream &operator<<(ostream &output, const MyVector &d); friend MyVector operator+(const MyVector &d1,const MyVector &d2);//向量相加,对应位置上的元素相加 friend MyVector operator-(const MyVector &d1,const MyVector &d2);//向量相减,对应位置上的元素相减 bool operator==(const MyVector &d);//判断两个矩阵是否相等,即对应位置上的所有元素是否相等private: int *Array; //Array 为动态数组指针,指向向量占用内存的起始地址 int num; //向量中元素个数};bool MyVector::operator==(const MyVector &d){ if(num!=d.num)return false; else for(int i=0; i<num; i++) if(Array[i]!=d.Array[i]) return false; else return true;}MyVector operator-(const MyVector &d1,const MyVector &d2){ //在此可以先判断d1和d2的元素数是否相同,如果不相同可以报错退出,不做运算。本参考解答忽略了这一前提 MyVector d(d1.num); for(int i=0; i<d1.num; ++i) { d.Array[i]=d1.Array[i]-d2.Array[i]; } return d;}MyVector operator+(const MyVector &d1,const MyVector &d2){ //在此可以先判断d1和d2的元素数是否相同,如果不相同可以报错退出,不做运算。本参考解答忽略了这一前提 MyVector d(d1.num); for(int i=0; i<d1.num; ++i) { d.Array[i]=d1.Array[i]+d2.Array[i]; } return d;}ostream &operator<<(ostream &output, const MyVector &d){ output<<"("; for(int i=0; i<d.num; i++) output<<d.Array[i]<<" "; output<<")"; return output;}istream &operator>>(istream &input, MyVector &d){ char c1='(',c2=')'; do { input>>c1; for(int i=0; i<d.num; i++) input>>d.Array[i]; input>>c2; }while(c1!='('||c2!=')'); return input;}MyVector::~MyVector(){ delete []Array;}MyVector::MyVector(int m){ num=m; Array=new int[num];}MyVector::MyVector(const MyVector&v){ for(int i=0; i<v.num; i++) Array[i]=v.Array[i];}int main(){ MyVector d1(5),d2(5); cout<<"输入d1——"; cin>>d1; cout<<"输入d2——"; cin>>d2; cout<<"d1="<<d1<<endl; cout<<"d2="<<d2<<endl; cout<<"d1+d2="<<d1+d2<<endl; cout<<"d1-d2="<<d1-d2<<endl; cout<<"d1"<<((d1==d2)?"==":"!=")<<"d2"<<endl; return 0;}
测试图:
运算符的重载和输出输入流·的重载极大地方便了软件开发者。
- 第九周项目4-我的向量类
- 第九周 项目4 我的向量类
- 第九周 【项目4-我的向量类】
- 第九周项目4 我的向量类
- 第九周项目4--我的向量类
- 第九周 【项目4-我的向量类】
- 第九周项目4——我的向量类
- 第九周【项目4-我的向量类】
- 第九周项目4-我的向量类
- 第九周项目4——我的向量类
- 第九周项目4-我的向量类
- 第九周上机项目4 我的向量类
- 第九周项目4-我的向量类
- 第九周 项目4-我的向量类
- 第九周项目4——我的向量类
- 第九周项目4:我的向量类
- 第九周项目4-我的向量类
- 第九周项目四:我的向量类
- oracle的启动和关闭
- 复数类中的运算符重载(续)
- 第7周项目4-string类的构造
- 第九周 【项目1-复数类中的运算符重载(续)】
- 【BZOJ3207】花神的嘲讽计划Ⅰ hash+可持久化线段树
- 第九周 【项目4-我的向量类】
- 第九周项目二
- Oracle的AWR报告分析
- 第八周上机项目 阅读程序
- redo 和 undo
- 第7周项目4-string类的构造
- 2014年第九周项目一:复数类中的运算符重载(续)
- 新浪看看
- STL 各种容器排序和查找算法对运算符的使用及特别注意运算符重载错误