日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

C++实践参考——数组类运算的实现

發(fā)布時間:2023/12/10 c/c++ 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C++实践参考——数组类运算的实现 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

【項目-數(shù)組類運算的實現(xiàn)】
  設計數(shù)組類Array,為了實現(xiàn)測試函數(shù)中要求的功能,請補足相關的函數(shù)(構造、析構函數(shù))和運算符重載的函數(shù)。
  實現(xiàn)策略提示:可以將測試函數(shù)中的語句加上注釋,取消一句的注釋,增加相應的函數(shù),以漸增地實現(xiàn)所有的功能,避免全盤考慮帶來的困難。

class Array { private:int* list; //用于存放動態(tài)分配的數(shù)組內存首地址int size; //數(shù)組大小(元素個數(shù)) public://成員函數(shù)聲明 }; //要求測試函數(shù)能夠運行出正確、合理的結果: 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; //用于存放動態(tài)分配的數(shù)組內存首地址int size; //數(shù)組大小(元素個數(shù)) public:Array(int sz = 50); //構造函數(shù)Array(int a[], int sz); //構造函數(shù)Array(const Array &a); //拷貝構造函數(shù)~Array(); //析構函數(shù)Array operator + (const Array &a2); //重載"="Array &operator = (const Array &a2); //重載"="int &operator[] (int i); //重載"[]"const int &operator[] (int i) const;int getSize() const; //取數(shù)組的大小void resize(int sz); //修改數(shù)組的大小void show() const; };Array::Array(int sz) //構造函數(shù) {assert(sz >= 0);//sz為數(shù)組大小(元素個數(shù)),應當非負size = sz; // 將元素個數(shù)賦值給變量sizelist = new int [size]; //動態(tài)分配size個int類型的元素空間 }Array::Array(int a[], int sz) {assert(sz >= 0);//sz為數(shù)組大小(元素個數(shù)),應當非負size = sz; // 將元素個數(shù)賦值給變量sizelist = new int [size]; //動態(tài)分配size個int類型的元素空間for (int i = 0; i < size; i++) //從對象X復制數(shù)組元素到本對象list[i] = a[i]; }Array::~Array() //析構函數(shù) {delete [] list; }//拷貝構造函數(shù) Array::Array(const Array &a) {size = a.size; //從對象x取得數(shù)組大小,并賦值給當前對象的成員//為對象申請內存并進行出錯檢查list = new int[size]; // 動態(tài)分配n個int類型的元素空間for (int i = 0; i < size; i++) //從對象X復制數(shù)組元素到本對象list[i] = a.list[i]; }Array Array::operator + (const Array &a2) {assert(size == a2.size); //檢查下標是否越界//如果本對象中數(shù)組大小與a2不同,則刪除數(shù)組原有內存,然后重新分配Array total(size);for (int i = 0; i < size; i++)total.list[i] = list[i]+a2.list[i];return total; }//重載"="運算符,將對象a2賦值給本對象。實現(xiàn)對象之間的整體賦值 Array &Array::operator = (const Array& a2) {if (&a2 != this){//如果本對象中數(shù)組大小與a2不同,則刪除數(shù)組原有內存,然后重新分配if (size != a2.size){delete [] list; //刪除數(shù)組原有內存size = a2.size; //設置本對象的數(shù)組大小list = new int[size]; //重新分配n個元素的內存}//從對象X復制數(shù)組元素到本對象for (int i = 0; i < size; i++)list[i] = a2.list[i];}return *this; //返回當前對象的引用 }//重載下標運算符,實現(xiàn)與普通數(shù)組一樣通過下標訪問元素,并且具有越界檢查功能 int &Array::operator[] (int n) {assert(n >= 0 && n < size); //檢查下標是否越界return list[n]; //返回下標為n的數(shù)組元素 } //常對象時,會調用這個函數(shù),運算結果(引用)將不能再被賦值 const int &Array::operator[] (int n) const {assert(n >= 0 && n < size); //檢查下標是否越界return list[n]; //返回下標為n的數(shù)組元素 }//取當前數(shù)組的大小 int Array::getSize() const {return size; }//將數(shù)組大小修改為sz void Array::resize(int sz) {assert(sz >= 0); //檢查sz是否非負if (sz == size) //如果指定的大小與原有大小一樣,什么也不做return;int* newList = new int [sz]; //申請新的數(shù)組內存int n = (sz < size) ? sz : size;//將sz與size中較小的一個賦值給n//將原有數(shù)組中前n個元素復制到新數(shù)組中for (int i = 0; i < n; i++)newList[i] = list[i];delete[] list; //刪除原數(shù)組list = newList; // 使list指向新數(shù)組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++实践参考——数组类运算的实现的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。