第12周项目3—数组类运算的实现

来源:互联网 发布:如何参加淘宝天天特价 编辑:程序博客网 时间:2024/06/06 16:59


//2.*Copyright(c) 2016.烟台大学计算机与控制工程学院
3.*ALL rights  reserved.
 4.*文件名称:main.cpp
 5.*作者:孙亚茹
6.*完成日期:2016年5月27日
7.*问题描述:设计数组类Array,补足相关的构造,析构函数和运算符重载函数,注意引用的用法。
8.*//

#include <iostream>#include <iomanip>#include <cassert>using namespace std;class Array{private:    int* list;          int size;       public:    //成员函数声明    Array(int sz = 50);    Array(int a[], int sz);    Array(const Array &a);    ~Array();    Array operator + (const Array &a2);    Array &operator = (const Array &a2);    int &operator[] (int i);    const int &operator[] (int i) const;    int getSize() const;    void resize(int sz);    void show()const;};Array::Array(int sz){    assert(sz >= 0);    size = sz;    list = new int [size];}Array::Array(int a[],int sz){     assert(sz >= 0);    size = sz;    size=sz;    list=new int[size];    int i;    for(i=0; i<size; i++)        list[i]=a[i];}Array:: ~Array(){    delete []list;}Array::Array(const Array &a){    size=a.size;    list=new int [size];    int i;    for(i=0; i<size; i++)        list[i]=a.list[i];}Array Array::operator + (const Array &a2){      assert(size == a2.size);    Array total(size);    for (int i = 0; i < size; i++)        total.list[i] = list[i]+a2.list[i];    return total;}Array &Array::operator = (const Array &a2){    int i;    if(&a2!=this)    {        if(a2.size!=size)        {            delete []list;            size=a2.size;            list=new int [size];            for(i=0; i<size; i++)                list[i]=a2.list[i];        }    }    return *this;}int &Array::operator[] (int n){    if(n>=0&&n<size);    return list[n];}const int &Array::operator[] (int n) const{    if(n >= 0 && n < size);     return list[n];         }int Array::getSize() const{    return size;}void Array::resize(int sz){    assert(sz >= 0);        if (sz == size)         return;    int* newList = new int [sz];        int n = (sz < size) ? sz : size;    for (int i = 0; i < n; i++)        newList[i] = list[i];    delete[] list;          list = newList;     size = sz;  }void Array::show()const{    int i;    for(i=0; i<size; i++)        cout<<list[i]<<" ";    cout<<endl;}//要求测试函数能够运行出正确、合理的结果:int main(){    int a[8]= {1,2,3,4,5,6,7,8};    int b[8]= {10,20,30,40,50,60,70,80};    Array array1(a,8),array3,array4;    const Array array2(b,8);    array4=array3=array1+array2;    array3.show();    array4.resize(20);    array4[8]=99;    cout<<array4[8]<<endl;    cout<<array2[3]<<endl;    return 0;}

总结:

          (1)数组要注意是否越界,讨论并重新分配内存,用动态数组要注意释放内存。

          (2)成员函数为引用时,在函数实现时引用符号要放在两个类名中间。

         (3)如果在多出用到一个变量,那么这个变量可以在开头声明为全局变量。

         

        

0 0
原创粉丝点击