SparseVector.hhnode
1 class SparseVector 2 { 3 private: 4 //結構體不必定會用到,不用初始化 5 struct node 6 { 7 int index; 8 int value; 9 node *next; 10 11 node(int index, int value, node *next = 0) : index(index), value(value), next(next) {} 12 }; 13 //這些纔是真正的數據成員,要初始化的 14 int size; 15 node *start; 16 17 void clear(); 18 void copyList(const SparseVector &sv); 19 void setNonzeroElem(int index, int value); 20 void removeElem(int index); 21 void checkListOrder(); 22 public: 23 SparseVector(int size); 24 const int getSize()const; 25 26 ~SparseVector(); 27 SparseVector(const SparseVector &sv); 28 SparseVector & operator= (const SparseVector &sv); 29 int getElem(int idx); 30 void setElem(int index, int value); 31 32 };
SparseVector.ccios
1 #include "SparseVector.hh" 2 #include <cassert> 3 #include <iostream> 4 using namespace std; 5 //單參數構造函數 6 SparseVector::SparseVector(int size):size(size) 7 { 8 start = 0; 9 } 10 11 const int SparseVector::getSize()const 12 { 13 return size; 14 } 15 //成員函數都默認帶有this指針,因此默認對調用這個函數的對象進行操做,因此不用再傳本對象的地址了。 16 void SparseVector::clear() 17 { 18 node *next; 19 node *current; 20 current = start; 21 while(current != 0) 22 { 23 next = current->next; 24 delete current; 25 current = next; 26 } 27 start = 0; 28 } 29 //對本對象進行操做,調用成員行數也是默認對本對象進行操做,不用傳本對象地址。 30 SparseVector::~SparseVector() 31 { 32 clear(); 33 } 34 35 void SparseVector::copyList(const SparseVector &sv) 36 { 37 size = sv.getSize(); 38 node *current; 39 node *otherCurrent =sv.start; 40 node *prev = 0; 41 42 while(otherCurrent != 0) 43 { 44 current = new node(otherCurrent->index, otherCurrent->value); 45 if(prev == 0) 46 { 47 start = current; 48 prev = current; 49 } 50 prev->next = current; 51 prev = current; 52 otherCurrent = otherCurrent->next; 53 } 54 } 55 56 SparseVector::SparseVector(const SparseVector &sv) 57 { 58 copyList(sv); 59 } 60 //注意自賦值,而且直接調用私有幫助函數。 61 SparseVector & SparseVector:: operator= (const SparseVector &sv) 62 { 63 if (this == &sv) 64 { 65 return *this; 66 } 67 clear(); 68 copyList(sv); 69 return *this; 70 } 71 //難點 72 int SparseVector::getElem(int idx) 73 { 74 node *current = start; 75 while(current != 0 && current->index < idx)//過濾,兩個條件 76 { 77 current = current->next; 78 } 79 if(current == 0)//注意判斷條件前後次序,先排除current爲0狀況 80 { 81 return 0; 82 } 83 else if(current->index == idx)//若是先執行這個,則current爲0時,會直接產生段錯誤 84 { 85 return current->value; 86 } 87 else 88 { 89 return 0; 90 } 91 } 92 //難點,分種狀況討論:1,初始爲空。2,插到最後面。3,插到最前面。4,插到中間。 93 void SparseVector::setNonzeroElem(int index, int value) 94 { 95 assert(value != 0); 96 node *current = start; 97 node *prev = 0; 98 99 if(start == 0)//容易遺漏,鏈表初始爲空的狀況。(1) 100 { 101 start = new node(index, value); 102 } 103 else//除此狀況外(2,3,4) 104 { 105 while(current != 0 && current->index < index)//過濾,兩個條件,保證current指向應該指的結點,或其以後的結點。prev指向值小於應該的結點。 106 { 107 prev = current; 108 current = current->next;//別忘了自增 109 } 110 /*2選1 111 * if(current == start)//插到最前面,current所指結點大於等於它 112 { 113 if(current->index == index)//等於 114 { 115 current->value = value; 116 } 117 else//大於 118 { 119 node *other = new node(index, value, start); 120 start = other; 121 } 122 } 123 else if(current == 0)//插到最後面,current所指結點小於它 124 { 125 node *other = new node(index, value, 0); 126 prev->next = other; 127 } 128 else//插到中間,current所指結點大於等於它 129 { 130 if(current->index == index)//current所指結點等於它 131 { 132 current->value = value; 133 } 134 else//current所指結點結點大於它 135 { 136 node *other = new node(index, value, current); 137 prev->next = other; 138 } 139 } 140 */ 141 if(current == 0)//插到最後邊 142 { 143 node *other = new node(index, value); 144 prev->next = other; 145 } 146 else if(current -> index == index)//current所指結點等於它的值 147 { 148 current->value =value; 149 } 150 else if(current == start)//在最開始的地方 151 { 152 node *other = new node(index, value, start); 153 start = other; 154 } 155 else //在中間 156 { 157 node *other = new node(index, value, current); 158 prev->next = other; 159 } 160 } 161 } 162 163 void SparseVector::removeElem(int index) 164 { 165 node *current = start; 166 node *prev = 0; 167 while(current != 0 && current->index < index)//過濾 168 { 169 prev = current; 170 current = current->next; 171 } 172 if(current->index == index)//若是是這個結點 173 { 174 if(current == start)//是開始結點 175 { 176 prev = current; 177 current = current->next; 178 delete prev; 179 start = current; 180 return; 181 } 182 else//是中間結點或者是後邊的節點(相同的) 183 { 184 prev->next = current->next; 185 delete current; 186 return; 187 } 188 } 189 else 190 { 191 return; 192 } 193 } 194 195 void SparseVector::setElem(int index, int value) 196 { 197 if(value != 0) 198 { 199 setNonzeroElem(index, value); 200 } 201 else 202 { 203 removeElem(index); 204 } 205 } 206 207 void SparseVector::checkListOrder() 208 { 209 node *current = start; 210 while(current != 0) 211 { 212 cout<<"("<<current->index<<" | "<<current->value<<")"<<endl; 213 current = current->next; 214 } 215 return; 216 }