cs11_c++_lab4a

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 };
View Code

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 }
View Code
相關文章
相關標籤/搜索
本站公眾號
   歡迎關注本站公眾號,獲取更多信息