版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、File chainNode.h#ifndef chainNode_#define chainNode_template <class T>struct chainNode / data members T element; chainNode<T> *next; / methods chainNode() next=NULL; chainNode(const T& element) this->element = element; this->next=NULL; chainNode(const T& element, chainNode&
2、lt;T>* next) this->element = element; this->next = next;#endifFile linnerList.h/ abstract class linearList/ abstract data type specification for linear list data structure/ all methods are pure virtual functions#ifndef linearList_#define linearList_#include <iostream>using namespace s
3、td;template<class T>class linearList public: virtual linearList() ; virtual bool empty() const = 0; / return true iff list is empty virtual int size() const = 0; / return number of elements in list virtual T& get(int theIndex) const = 0; / return element whose index is theIndex virtual int
4、 indexOf(const T& theElement) const = 0; / return index of first occurence of theElement virtual void erase(int theIndex) = 0; / remove the element whose index is theIndex virtual void insert(int theIndex, const T& theElement) = 0; / insert theElement so that its index is theIndex virtual vo
5、id output(ostream& out) const = 0; / insert list into stream out;#endifFile circularListWithHeader.h/ circularList list with header node and iterator#ifndef circularListWithHeader_#define circularListWithHeader_#include<iostream>#include<sstream>#include<string>#include "c
6、hainNode.h"#include "myExceptions.h"#include "linearList.h"using namespace std;template<class T>class circularListWithHeader public: / 構(gòu)造函數(shù) circularListWithHeader(); / some methods bool empty()return listSize = 0; int size() const return listSize; T& get(int theInd
7、ex) const; int indexOf(const T& theElement) const; void erase(int theIndex); void insert(int theIndex, const T& theElement); void output(ostream& out) const; void reverse(); / iterators to start and end of list class iterator; iterator begin() return iterator(headerNode->next); iterat
8、or end() return iterator(headerNode); / iterator for chain class iterator public: / typedefs required by C+ for a forward iterator typedef forward_iterator_tag iterator_category; typedef T value_type; typedef ptrdiff_t difference_type; typedef T* pointer; typedef T& reference; / 構(gòu)造函數(shù) iterator(ch
9、ainNode<T>* theNode = NULL) node = theNode; / 解引用操作符 T& operator*() const return node->element; T* operator->() const return &node->element; / 迭代器加法操作 iterator& operator+() / preincrement node = node->next; return *this; iterator operator+(int) / postincrement iterator
10、old = *this; node = node->next; return old; / 相等檢驗 bool operator!=(const iterator right) const return node != right.node; bool operator=(const iterator right) const return node = right.node; protected: chainNode<T>* node; ; / end of iterator class protected: void checkIndex(int theIndex) co
11、nst; / 如果索引無效,拋出異常 chainNode<T>* headerNode; / 指向鏈表第一個元素的指針 int listSize; / 元素個數(shù);template<class T>circularListWithHeader<T>:circularListWithHeader()/ 構(gòu)造函數(shù) headerNode = new chainNode<T>(); headerNode->next = headerNode; listSize = 0;template<class T>void circularListW
12、ithHeader<T>:checkIndex(int theIndex) const/ 確定 theIndex在 0和listSize - 1之間轉(zhuǎn)換. if (theIndex < 0 | theIndex >= listSize) ostringstream s; s << "index = " << theIndex << " size = " << listSize; throw illegalIndex(s.str(); template<class T>T&
13、amp; circularListWithHeader<T>:get(int theIndex) constcheckIndex(theIndex);chainNode<T>* currentNode = headerNode->next;for(int i = 0;i<theIndex;i+)currentNode = currentNode->next;return currentNode->element;template<class T>int circularListWithHeader<T>:indexOf(c
14、onst T& theElement) const/ Return元素theElement首次出現(xiàn)時的索引. / 如果不存在Return -1 . /將theElement放入headerNode headerNode->element = theElement; / 在鏈表中尋找 theElement chainNode<T>* currentNode = headerNode->next;/指向鏈表的第一個 int index = 0; / 返回的索引,從0開始計數(shù) while (currentNode->element != theElement)
15、/ 移動到下一節(jié)點 currentNode = currentNode->next; index+; / 確定是否找到element if (currentNode = headerNode) return -1; else return index;template<class T>void circularListWithHeader<T>:erase(int theIndex)/ Delete索引為theIndex的元素. / 如果不存在這樣的元素就拋出異常.checkIndex(theIndex);/索引有效,需找要刪除的元素節(jié)點chainNode<
16、T>* deleteNode;/ use p 指向要刪除節(jié)點的前驅(qū)結(jié)點chainNode<T>* p = headerNode->next;for(int i = 0;i < theIndex - 1;i+)p = p->next;deleteNode = p->next;p->next = p->next->next;/ 刪除 deleteNode指向的節(jié)點listSize-;delete deleteNode;template<class T>void circularListWithHeader<T>:i
17、nsert(int theIndex, const T& theElement)/ Insert theElement so that its index is theIndex. if (theIndex < 0 | theIndex > listSize) / 無效索引 ostringstream s; s << "index = " << theIndex << " size = " << listSize; throw illegalIndex(s.str(); / find 新
18、元素前驅(qū) chainNode<T>* p = headerNode; for (int i = 0; i < theIndex; i+) p = p->next; / insert after p p->next = new chainNode<T>(theElement, p->next); listSize+;template<class T>void circularListWithHeader<T>:output(ostream& out) const/ 把鏈表放入輸出流. for (chainNode&l
19、t;T>* currentNode = headerNode->next; currentNode != headerNode; currentNode = currentNode->next) out << currentNode->element << " "/ overload <<template <class T>ostream& operator<<(ostream& out, const circularListWithHeader<T>&
20、x) x.output(out); return out;template<class T>void circularListWithHeader<T>:reverse()if(listSize <= 1) return;chainNode<T>*currentNode = headerNode->next,*nextNode,*lastNode = headerNode;while(currentNode != headerNode)nextNode = currentNode->next;currentNode->next = l
21、astNode;lastNode = currentNode;currentNode = nextNode;headerNode->next = lastNode;File circularListWithHeader.cpp/ test the class circularListWithHeader#include<iostream>#include "circularListWithHeader.h"#include<numeric>using namespace std;int main() / test constructor cir
22、cularListWithHeader<int> y; / test size cout <<"Initial size of y =" << y.size() << endl; / test insert y.insert(0, 2); y.insert(1, 6); y.insert(0, 1); y.insert(2, 4); y.insert(3, 5); y.insert(2, 3); cout << "Inserted 6 integers, list y should be 1 2 3 4
23、5 6" << endl; cout << "Size of y = " << y.size() << endl; y.output(cout); cout << endl << "Testing overloaded <<" << endl; cout << y << endl; / test iterator cout << endl <<"Ouput using forward iter
24、ators pre and post +" << endl; for (circularListWithHeader<int>:iterator i = y.begin(); i != y.end(); i+) cout << *i << " " cout << endl; for(circularListWithHeader<int>:iterator i = y.begin(); i != y.end(); +i) cout << *i << " &quo
25、t; *i += 1; cout << endl; / test indexOf int index = y.indexOf(4); if (index < 0) cout << "4 not found" << endl; else cout << "The index of 4 is " << index << endl; index = y.indexOf(7); if (index < 0) cout << "7 not found"
26、; << endl; else cout << "The index of 7 is " << index << endl; int sum = accumulate(y.begin(), y.end(), 0);/初始值是0 cout << "The sum of the elements is " << sum << endl; /test reverse y.reverse(); cout<<y<<endl; return 0;#endifF
27、ile myExceptions.h/ exception classes for various error types#ifndef myExceptions_#define myExceptions_#include <string>using namespace std;/ illegal parameter valueclass illegalParameterValue public: illegalParameterValue(string theMessage = "Illegal parameter value") message = theM
28、essage; void outputMessage() cout << message << endl; private: string message;/ illegal input dataclass illegalInputData public: illegalInputData(string theMessage = "Illegal data input") message = theMessage; void outputMessage() cout << message << endl; private: s
29、tring message;/ illegal indexclass illegalIndex public: illegalIndex(string theMessage = "Illegal index") message = theMessage; void outputMessage() cout << message << endl; private: string message;/ matrix index out of boundsclass matrixIndexOutOfBounds public: matrixIndexOutO
30、fBounds (string theMessage = "Matrix index out of bounds") message = theMessage; void outputMessage() cout << message << endl; private: string message;/ matrix size mismatchclass matrixSizeMismatch public: matrixSizeMismatch(string theMessage = "The size of the two matrics doesn't match") message = theMessage; void outputMessage() cout << message << endl; private: string message;/ stack is emptyclass stackEmpty public: stackEmpty(string theMessage = "Invalid operation on empty stack
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 乳制品公司職工食堂租賃條款
- 商業(yè)綜合體造價員招聘合同
- 林業(yè)科技HSE管理協(xié)議
- 服裝租賃解除協(xié)議書
- 文化中心靜壓樁施工承包合同
- 環(huán)保項目土地租賃合同
- 航空特種車輛機坪作業(yè)協(xié)調(diào)
- 航空航天技術合作簽約管理辦法
- 2024年房地產(chǎn)銷售擔保合同范本及開發(fā)商責任約定書3篇
- 2025版空調(diào)銷售與智能安裝升級合同3篇
- 選礦年度工作總結(jié)報告
- 彈性力學材料模型:彈塑性材料:彈塑性本構(gòu)關系技術教程
- 2024至2030年阜陽市醫(yī)養(yǎng)結(jié)合模式調(diào)查及市場投融可行性報告
- 2023-2024學年部編版語文四年級上冊期末測試卷(附答案解析)
- 2024年高考英語一模試題分類匯編:概要寫作(上海專用)(解析版)
- 院內(nèi)突發(fā)心跳呼吸驟停、昏迷、跌倒事件應急預案及程序
- 2023年山東省濟南市章丘市棗園街道社區(qū)工作者招聘筆試題及答案
- 人教版道德與法治六年級上冊全冊單元測試卷課件
- 2024年全國注冊土木工程師(水利水電)之專業(yè)知識考試歷年考試題(附答案)
- 2024年勞務用工合同
- 2024年新疆中考數(shù)學真題試卷及答案
評論
0/150
提交評論