第十四周实验报告任务1
2012-05-22 17:25
661 查看
#include <iostream> using namespace std; class MyArray { private: int *arr; //用于存放动态分配的数组内存首地址 int size; //数组大小 public: MyArray(int sz=50); MyArray(int a[],int sz); //由一个内置类型的数组初始化 MyArray(const MyArray &A); //拷贝构造函数 ~MyArray(void); //析构函数,注意释放空间 MyArray&operator =(const MyArray &A); //重载“=”使得数组对象可以整体赋值 int& operator[](int i); //重载[],使得Array对象也可以如C++普通数组一样,用a[i]形式取出值【选做】 bool operator == (MyArray& A); //重载==,使得Array对象能整体判断两个数组是否相等(size相等且对应元素相等) MyArray operator + (MyArray& A); //重载+,使两个Array对象可以整体相加(前提大小相等)【选做】 friend ostream& operator << (ostream& out,MyArray& A); //重载<<,输出数组 int GetSize(void)const; //取数组大小; void Resize(int sz); //修改数组的大小,如果sz大于数组的原大小,增加的元素初始为;sz小于数组的原大小,舍弃后面的元素【选做】 }; MyArray::MyArray(int sz) { arr=new int[sz]; size=sz; for(int i=0;i<sz;i++) arr[i]=0; } MyArray::MyArray(int a[],int sz) { arr=new int[sz]; size=sz; for(int i=0;i<sz;i++) *(arr+i)=*(a+i); } MyArray::MyArray(const MyArray &A) { arr=new int[A.size ]; for(int i=0;i<A.size ;i++) *(arr+i)=*(A.arr +i); size=A.size; } MyArray::~MyArray(void) { delete []arr; } MyArray &MyArray::operator =(const MyArray &A) { arr=new int[A.size ]; for(int i=0;i<A.size;i++) *(arr+i)=*(A.arr+i); size=A.size ; return *this; } int &MyArray:: operator[](int i)//重载[],使得Array对象也可以如C++普通数组一样,用a[i]形式取出值【选做】 { if(i > size) { cout << "数组角标越界" << endl; exit(0); } else { return *(arr + i); } } bool MyArray::operator ==(MyArray &A) { if(size==A.size ) { for(int i=0;i<size;i++) { if(arr[i]!=A.arr[i]) return false; } return true; } else return false; } MyArray MyArray::operator + (MyArray& A) //重载+,使两个Array对象可以整体相加(前提大小相等)【选做】 { MyArray My(A); if(size != A.size) { cout << "数组元素个数不同,无法相加。" << endl; } else { for(int i = 0; i < size; ++i) { *(My.arr + i) = *(arr + i) + *(A.arr+i); } return My; } } ostream& operator << (ostream& out,MyArray& A) { for(int i=0;i<A.size ;i++) { out<<*(A.arr+i)<<" "; } out<<endl; return out; } int MyArray:: GetSize(void)const { return size; } void MyArray::Resize(int sz) //修改数组的大小,如果sz大于数组的原大小,增加的元素初始为;sz小于数组的原大小,舍弃后面的元素【选做】 { int *m,i; m = new int[sz]; if(sz > size) { for( i = 0; i < size; ++i) *(m + i) = *(arr + i); for(i = size; i < sz; ++i) *(m + i) = 0; } else { for(i = 0; i < sz; ++i) *(m + i) = *(arr + i); } arr = new int[sz]; for(i = 0;i < sz; ++i) *(arr + i) = *(m + i); size = sz; } int main() { int a[10]={1,2,3,4,5,6,7,8,9,10}; int b[10]={4,5,6,7,8,9,10,11,12,13}; MyArray arr1(a,10); MyArray arr2(b,10); MyArray arr3(10); cout<<arr3; arr3 = arr1 +arr2; cout<<arr3; arr3.Resize(20); cout<<arr3; arr3.Resize(5); cout<<arr3; system("pause"); return 0; }
运行结果:
0 0 0 0 0 0 0 0 0 0
5 7 9 11 13 15 17 19 21 23
5 7 9 11 13 15 17 19 21 23 0 0 0 0 0 0 0 0 0 0
5 7 9 11 13
请按任意键继续. . .
相关文章推荐
- 第十四周实验报告(任务二)
- 第十四周实验报告(任务一)【数组类的构造】
- 第十四周实验报告(任务二)【待修改】
- 《第十四周实验报告任务2》
- C++程序设计实验报告(七十三)---第十四周任务一
- C++程序设计实验报告(七十四)---第十四周任务二
- 第十四周实验报告 任务一
- 第十四周实验报告(任务一)
- 第十四周实验报告 任务1
- 第四周实验报告任务4
- 《第六周实验报告任务2》
- 第六周实验报告 任务二
- 第六周实验报告(任务二)【补充代码】
- 第七周实验报告任务二
- 第七周实验报告(任务1)
- 《第九周实验报告任务1》
- 第九周实验报告任务五
- 第九周实验报告任务4 建立一个二维数组类Douary,使该类中有以下数据成员、成员函数及友员函数,完成矩阵的输入、输出、加、减、相等判断等操作。
- 第十周实验报告 任务一
- 第十周实验报告任务1