這篇文章將為大家詳細講解有關怎么在C++中實現數組類運算,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
創新互聯建站堅持“要么做到,要么別承諾”的工作理念,服務領域包括:網站設計制作、網站設計、企業官網、英文網站、手機端網站、網站推廣等服務,滿足客戶于互聯網時代的八公山網站設計、移動媒體設計的需求,幫助企業找到有效的互聯網解決方案。努力成為您成熟可靠的網絡建設合作伙伴!【項目-數組類運算的實現】
設計數組類Array,為了實現測試函數中要求的功能,請補足相關的函數(構造、析構函數)和運算符重載的函數。
實現策略提示:可以將測試函數中的語句加上注釋,取消一句的注釋,增加相應的函數,以漸增地實現所有的功能,避免全盤考慮帶來的困難。
class Array { private: int* list; //用于存放動態分配的數組內存首地址 int size; //數組大小(元素個數) public: //成員函數聲明 }; //要求測試函數能夠運行出正確、合理的結果: 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; }
[參考解答]
#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);//sz為數組大小(元素個數),應當非負 size = sz; // 將元素個數賦值給變量size list = new int [size]; //動態分配size個int類型的元素空間 } Array::Array(int a[], int sz) { assert(sz >= 0);//sz為數組大小(元素個數),應當非負 size = sz; // 將元素個數賦值給變量size list = new int [size]; //動態分配size個int類型的元素空間 for (int i = 0; i < size; i++) //從對象X復制數組元素到本對象 list[i] = a[i]; } Array::~Array() //析構函數 { delete [] list; } //拷貝構造函數 Array::Array(const Array &a) { size = a.size; //從對象x取得數組大小,并賦值給當前對象的成員 //為對象申請內存并進行出錯檢查 list = new int[size]; // 動態分配n個int類型的元素空間 for (int i = 0; i < size; i++) //從對象X復制數組元素到本對象 list[i] = a.list[i]; } Array Array::operator + (const Array &a2) { assert(size == a2.size); //檢查下標是否越界 //如果本對象中數組大小與a2不同,則刪除數組原有內存,然后重新分配 Array total(size); for (int i = 0; i < size; i++) total.list[i] = list[i]+a2.list[i]; return total; } //重載"="運算符,將對象a2賦值給本對象。實現對象之間的整體賦值 Array &Array::operator = (const Array& a2) { if (&a2 != this) { //如果本對象中數組大小與a2不同,則刪除數組原有內存,然后重新分配 if (size != a2.size) { delete [] list; //刪除數組原有內存 size = a2.size; //設置本對象的數組大小 list = new int[size]; //重新分配n個元素的內存 } //從對象X復制數組元素到本對象 for (int i = 0; i < size; i++) list[i] = a2.list[i]; } return *this; //返回當前對象的引用 } //重載下標運算符,實現與普通數組一樣通過下標訪問元素,并且具有越界檢查功能 int &Array::operator[] (int n) { assert(n >= 0 && n < size); //檢查下標是否越界 return list[n]; //返回下標為n的數組元素 } //常對象時,會調用這個函數,運算結果(引用)將不能再被賦值 const int &Array::operator[] (int n) const { assert(n >= 0 && n < size); //檢查下標是否越界 return list[n]; //返回下標為n的數組元素 } //取當前數組的大小 int Array::getSize() const { return size; } //將數組大小修改為sz void Array::resize(int sz) { assert(sz >= 0); //檢查sz是否非負 if (sz == size) //如果指定的大小與原有大小一樣,什么也不做 return; int* newList = new int [sz]; //申請新的數組內存 int n = (sz < size) ? sz : size;//將sz與size中較小的一個賦值給n //將原有數組中前n個元素復制到新數組中 for (int i = 0; i < n; i++) newList[i] = list[i]; delete[] list; //刪除原數組 list = newList; // 使list指向新數組 size = sz; //更新size } void Array::show() const { for (int 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; }
關于怎么在C++中實現數組類運算就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
另外有需要云服務器可以了解下創新互聯建站vcdvsql.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
文章題目:怎么在C++中實現數組類運算-創新互聯
瀏覽路徑:http://vcdvsql.cn/article8/ddpiop.html
成都網站建設公司_創新互聯,為您提供網站排名、App開發、外貿建站、品牌網站制作、動態網站、網站制作
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯