版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上設計動態(tài)數(shù)組的基本應用與實現(xiàn)1.1需求陳述數(shù)組是應用程序中經(jīng)常要用到的一種數(shù)據(jù)結(jié)構(gòu)。雖然通過數(shù)組可以對大量的數(shù)據(jù)和對象進行有效的管理,但很多情況下,在程序運行之前,并不能夠確切地知道數(shù)組中會有多少元素,這時候數(shù)組到底聲明為多大,就是一個很麻煩的問題。在C+中,動態(tài)內(nèi)存分配技術(shù)可以保證程序在運行過程中按照實際需要申請適量的內(nèi)存,使用結(jié)束后還可以釋放。這樣就使得在運用數(shù)組時更加方便,有效。1.2需求分析1.2.1功能分析表1 函數(shù)庫功能分析項目功能函數(shù)Array主體函數(shù)主函數(shù):int main()運行函數(shù):Array:run()數(shù)組的操作插入元素:Array:insert
2、(const int & index, const int & value)刪除元素:Array:remove(const int& index) 追加元素:Array:append(const int& value) 查看數(shù)組大小:Array:size()查看數(shù)組容量:Array:capacity()查看數(shù)組是否為空:Array:empty()類的函數(shù)構(gòu)造函數(shù):Array:Array(const int& capcity) :_size(0), _capacity(capcity)拷貝構(gòu)造函數(shù):Array:Array(const Array&
3、other) :_size(other._size), _capacity(other._capacity)析構(gòu)函數(shù):Array:Array()1.2.2數(shù)據(jù)分析數(shù)組最初默認為空,并且容量為10。由于使用動態(tài)內(nèi)存分配,所以在存入數(shù)據(jù)時不必擔心數(shù)組大小的影響,數(shù)組容量不夠時可以自動分配新的內(nèi)存存儲數(shù)據(jù)。對數(shù)組進行不同的操作時,數(shù)組也會根據(jù)實際需要進行動態(tài)的內(nèi)存分配。這樣使得數(shù)組的應用更加方便、靈活,同時提高了效率。為提高函數(shù)的可靠性,我們對每個函數(shù)的測試準備了23套測試數(shù)據(jù)。1.2.3技術(shù)約束本函數(shù)庫的測試系統(tǒng)已在code blocks下編譯通過。1.3總體設計1.3.1 數(shù)據(jù)結(jié)構(gòu)數(shù)組所采用的數(shù)
4、據(jù)結(jié)構(gòu)是類。聲明一個數(shù)組類,在將對數(shù)組進行的各項操作聲明為類的函數(shù),通過調(diào)用各個函數(shù)來實現(xiàn)對數(shù)組的各項操作功能。具體定義形式為:class Array int _size;/元素個數(shù) int _capacity;/容量 int* items;/動態(tài)數(shù)組public: Array(const int& capcity = 16);/構(gòu)造函數(shù) Array(const Array& other);/拷貝構(gòu)造函數(shù) Array& operator = (const Array& other);/ Array();/析構(gòu)函數(shù) void insert(const int&am
5、p; index, const int& value);/插入函數(shù) void remove(const int& index);/刪除函數(shù) void append(const int& value);/追加函數(shù) void run();/運行函數(shù);1.3.2 函數(shù)功能a. 主函數(shù)(選擇界面函數(shù)):int main()功能:使用戶來選擇要對數(shù)組進行的操作。關(guān)鍵代碼: Array a(10);/聲明一個動態(tài)數(shù)組類的對象 cout<<"*t"<<endl;cout<<"*請選擇你想對動態(tài)數(shù)組的操作*tt"
6、;<<endl;cout<<" 1、插入元素 2、追加元素 3、查看數(shù)組大小 tt"<<endl;cout<<" 4、查看數(shù)組容量 5、刪除元素 6、顯示元素 tt"<<endl;cout<<"*t"<<endl;cout<<"提示:輸入0即可退出程序 t"<<endl;cout<<" 目前數(shù)組為空,建議追加元素后再進行其他操作tt"<<endl;cout<&
7、lt;"*t"<<endl; a.run();測試數(shù)據(jù): 優(yōu)點:讓用戶自己選擇需要進行的操作,更加人性化。b. 插入元素函數(shù):Array:insert(const int & index, const int & value)設計思想:首先選擇要插入元素的位置,位置錯誤則報錯;位置正確則進行下一步判斷。如果數(shù)組容量可以繼續(xù)存放數(shù)據(jù),則把items + index所指向的內(nèi)存空間的數(shù)據(jù)全部拷貝到items + (index + 1)所指向的內(nèi)存地址上,然后把所要插入的元素賦值給所選擇的數(shù)組下標位置tmpindex上,這樣完成元素插入過程。如果當前數(shù)
8、組容量不能繼續(xù)存放數(shù)據(jù),則需要重新申請內(nèi)存用于存放數(shù)據(jù),然后完成元素插入。功能:把新元素插入數(shù)組中兩元素之間關(guān)鍵代碼: if (index < 0 | index >= _size )/如果輸入下標位置小于零或大于等于元素個數(shù)則報錯 cout << "輸入位置不正確!"<<"t"<<endl; if (_size < _capacity) /如果當前容量可以繼續(xù)存放元素 memmove(items + (index + 1), items + index, (_size - index) * size
9、of(int);/ itemsindex = value;/把要插入的元素存入所選位置 else _capacity *= 2;/容量不夠,再開辟同樣長度內(nèi)存空間 int* tmp = new int_capacity; /用指針tmp指向new動態(tài)分配的長度為_capacity*sizeof(int)的內(nèi)存空間 memcpy(tmp, items, index * sizeof(int);/ memcpy(tmp + (index + 1), items + index, (_size - index)* sizeof(int);/ tmpindex = value;/把要插入的元素存入所選
10、位置 delete tmp;/注銷指針tmp,使程序釋放用new開辟的內(nèi)存空間 +_size;/插入一個元素所以元素個數(shù)加一測試數(shù)據(jù):優(yōu)點:可以把想要存入數(shù)組的元素放入數(shù)組中任意位置(數(shù)組末尾除外)c.追加元素函數(shù):Array:append(const int & value)設計思想:首先判斷當前數(shù)組容量是否可以繼續(xù)存放數(shù)據(jù),若可以,則直接將該元素存放于數(shù)組末尾,完成元素追加。若容量不夠,則需要繼續(xù)申請內(nèi)存空間,然后將該元素存于數(shù)組末尾即可。功能:把元素直接存放于數(shù)組末尾。關(guān)鍵代碼:if (_size < _capacity) /如果當前容量可以繼續(xù)存放元素 items_siz
11、e = value;/直接把元素存入數(shù)組末尾 else _capacity *= 2;/容量不夠,再開辟同樣長度內(nèi)存空間 int* tmp = new int_capacity;/用指針tmp指向new動態(tài)分配的長度為_capacity*sizeof(int)的內(nèi)存空間 memcpy(tmp, items, _size * sizeof(int);/ tmp_size = value;/直接把元素存入數(shù)組末尾 delete tmp;/注銷指針tmp,使程序釋放用new開辟的內(nèi)存空間 +_size;/追加一個元素所以元素個數(shù)加一測試數(shù)據(jù):d. 刪除元素函數(shù):Array:remove(const
12、int& index) 設計思想:首先判斷要刪除的元素位置是否正確,若不正確,則報錯。若輸入正確,則精選下一步判斷。首先元素個數(shù)_size減一,判斷所選位置是否等于元素個數(shù)_size,即要刪除的元素是否為最后一位。若是,則直接將最后一位元素抹掉即可,若不是最后一位,則把items + (index + 1)所指向的內(nèi)存空間中的數(shù)據(jù)拷貝到items + index 所指向的內(nèi)存地址上,此時會將tmpindex元素覆蓋,即將其刪除。 功能:刪除數(shù)組中任意一個元素。 關(guān)鍵代碼: if (index < 0 | index >= _size)/如果輸入的下標位置小于零或大于元素個數(shù)
13、則 cout << "輸入位置不正確!"<<"t"<<endl;/輸出錯誤 -_size;/如果輸入正確則元素個數(shù)減一 if (index != _size)/ memmove(items + index, items + (index + 1), (_size - index) * sizeof(int);/測試數(shù)據(jù):優(yōu)點:可以刪除不想要的元素。e.查看數(shù)組大小函數(shù) :Array:size() 設計思想:直接返回數(shù)組中的元素個數(shù)即可。功能:查看數(shù)組中的元素個數(shù)。關(guān)鍵代碼:return _size;測試數(shù)據(jù):優(yōu)點:可以
14、查看數(shù)組中元素個數(shù)。f.查看數(shù)組容量函數(shù):Array:capacity() 設計思想:數(shù)組一開始默認容量_capacity為10,當容量不夠時會自動申請同長內(nèi)存空間。直接返回_capacity即可。功能:查看數(shù)組容量。關(guān)鍵代碼:return _capacity; 測試數(shù)據(jù):1.初始數(shù)組容量:2.申請內(nèi)存空間后:優(yōu)點:可以準確查看數(shù)組容量變化。g. 運行函數(shù):Array:run()設計思想:由用戶根據(jù)選擇界面選擇要進行的操作,函數(shù)根據(jù)switch結(jié)構(gòu)來調(diào)用上述幾個函數(shù)實現(xiàn)其功能。功能:調(diào)用各個函數(shù)以實現(xiàn)操作功能。關(guān)鍵代碼:char key;int i ,num,value;/num是下標位置變量
15、,value是元素值變量cout << "請輸入你的選擇:"<<"t"<<endl;cin >> key;while(key!='0')switch(key)case '1':/插入元素 if(_size < 1)/如果數(shù)組為空則顯示無法插入 cout<<"目前數(shù)組無法插入元素!tt"<<"t"<<endl; break; elsecout<<"請輸入插入元素的位置:t&q
16、uot;<<endl;cin>>num;if(num > _size-1)/如果輸入的位置不存在 cout<<"您輸入的位置無法插入元素!tt"<<"t"<<endl; break; else cout<<"請輸入插入元素的值:t"<<endl; cin>> value; insert(num, value);/執(zhí)行插入函數(shù) break; case '2':/追加元素cout<<"請輸入追加元素的
17、值:t"<<endl;cin >> value;append(value);/執(zhí)行追加函數(shù)break;case '3':/查看數(shù)組大小cout<<"動態(tài)數(shù)組的大小為:t"<<size()<<endl;/執(zhí)行查看數(shù)組大小函數(shù)break;case '4':/查看數(shù)組容量cout<<"動態(tài)數(shù)組的容量為:t"<<capacity()<<endl;/執(zhí)行查看數(shù)組容量函數(shù)break;case '5':/刪除元素 i
18、f(_size < 1)/如果數(shù)組為空 cout<<"目前數(shù)組無法刪除元素!tt"<<"t"<<endl; break; elsecout<<"請輸入你想刪除的元素的位置:t"<<endl;cin>>num;if(num > _size-1)/如果輸入的位置不存在 cout<<"您輸入的位置為空白,無法刪除!tt"<<"t"<<endl; break; elseremove(num);/執(zhí)行刪除元素函數(shù)break; case '6': if(_size < 1)/如果數(shù)組為空 cout<<"目前數(shù)組為空,無法顯示!"<<"t"<<endl; else cout<<"目前數(shù)組元素為:"<<e
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 測控電路課程設計論文
- 2024年度綠色環(huán)保大棚租賃服務協(xié)議范本3篇
- 2024年涂料品牌代理商合同3篇
- 晶體管值測試課程設計
- 2024年綜合材料籃球場地施工合同
- 2024年海上運輸合同模板
- 2024年游戲作品授權(quán)委托合同范本3篇
- 2024年版城市供水特許經(jīng)營權(quán)授予協(xié)議書
- 工廠照明問題課程設計
- 2024年經(jīng)典房屋買賣協(xié)議示范文本版B版
- 化工過程安全管理導則學習考試題及答案
- 關(guān)于拖欠民營企業(yè)中小企業(yè)的2024年清理拖欠民營企業(yè)中小企業(yè)賬款工作方案
- 冀少版八年級下冊生物期末復習知識點考點提綱
- 2024年全國高考數(shù)學試題及解析答案(新課標Ⅱ卷)
- 八年級語文上冊《作文》專項測試卷及答案
- 2024年廣東省汕尾市海豐縣六上數(shù)學期末教學質(zhì)量檢測試題含解析
- 保安項目人員替換方案
- 國外合同協(xié)議書
- 癌癥患者生活質(zhì)量量表EORTC-QLQ-C30
- 建筑工程技術(shù)專業(yè)《建筑工程質(zhì)量與安全管理》課程標準
- 7.4 等差數(shù)列與等比數(shù)列的應用(課件)-【中職專用】高二數(shù)學(高教版2021·拓展模塊一下冊)
評論
0/150
提交評論