青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 183,  comments - 10,  trackbacks - 0

標準庫里的 list 實現(xiàn)是通過雙向鏈表實現(xiàn)的。這里沒有使用雙向鏈表,自然功能也就不能像標準庫里的 list 那樣完備。不支持逆向。

這里在單向鏈表的基礎(chǔ)上,加入了泛型,迭代器,盡可能多地添加一些接口,已盡量像標準庫里的 list 那樣操作。另外,這里沒有過多里涉及內(nèi)存分配的問題。每次插入的時候是直接分配一個元素的空間,而不是采用 2 倍法則。

總體上,還沒有看過 STL 里 list 具體是怎么實現(xiàn)的,只是按照自己的想法隨意寫了一下。

  1 #include <iostream>
  2 using namespace std;
  3 
  4 template <typename Type>
  5 class mylist
  6 {
  7 public:
  8     typedef Type value_type;
  9     typedef unsigned int size_type;
 10     struct node_
 11     {
 12         value_type data;
 13         node_*     next;
 14     };
 15     typedef node_  Node;
 16     typedef node_* PNode;
 17     struct iterator
 18     {
 19     private:
 20         PNode iter_;
 21     public:
 22         iterator(PNode p) : iter_(p) {}
 23         iterator() {}
 24         iterator(const iterator& i) : iter_(i) {}
 25         iterator& operator =(const iterator& i)
 26         {
 27             iter_ = i.iter_;
 28         }
 29         value_type operator *()
 30         {
 31             return iter_->data;
 32         }
 33         PNode operator ->()
 34         {
 35             return iter_;
 36         }
 37         PNode getPNode()
 38         {
 39             return iter_;
 40         }
 41         iterator& operator ++()
 42         {
 43             iter_ = iter_->next;
 44             return *this;
 45         }
 46         const iterator operator ++(int)
 47         {
 48             iterator t(iter_);
 49             ++iter_;
 50             return t;
 51         }
 52         friend bool operator ==(const iterator& lhs, const iterator& rhs)
 53         {
 54             return lhs.iter_ == rhs.iter_;
 55         }
 56         friend bool operator !=(const iterator& lhs, const iterator& rhs)
 57         {
 58             return !(lhs == rhs);
 59         }
 60     };
 61     typedef const iterator const_iterator;
 62 private:
 63 // public:
 64     PNode head;
 65     size_type size_;
 66     PNode tail;
 67 public:
 68     mylist()
 69     {
 70         head = new Node;
 71         if (head == 0)
 72         {
 73             exit(1);
 74         }
 75         head->next = 0;
 76         size_ = 0;
 77         tail = head;
 78     }
 79     mylist(const mylist<Type>& m)
 80     {
 81         head = new Node;
 82         if (head == 0)
 83         {
 84             exit(1);
 85         }
 86         head->next = 0;
 87         size_ = 0;
 88         tail = head;
 89         PNode p, q = head;
 90         for (mylist<Type>::iterator iter = m.begin(); iter != m.end(); ++iter)
 91         {
 92             p = new Node;
 93             if (p == 0)
 94             {
 95                 exit(1);
 96             }
 97             // p->data = iter.getPNode()->data;
 98             p->data = iter->data;
 99             p->next = 0;
100             q->next = p;
101             q = p;
102             tail = p;
103             ++size_;
104         }
105     }
106     mylist<Type>& operator =(const mylist<Type>& rhs)
107     {
108         if (this != &rhs)
109         {
110             clear();
111             head = new Node;
112             if (head == 0)
113             {
114                 exit(1);
115             }
116             head->next = 0;
117             size_ = 0;
118             tail = head;
119             PNode p, q = head;
120             for (mylist<Type>::iterator iter = rhs.begin(); iter != rhs.end(); ++iter)
121             {
122                 p = new Node;
123                 if (p == 0)
124                 {
125                     exit(1);
126                 }
127                 p->data = iter->data;
128                 p->next = 0;
129                 q->next = p;
130                 q = p;
131                 tail = p;
132                 ++size_;
133             }
134         }
135         return *this;
136     }
137     ~mylist()
138     {
139         clear();
140     }
141     //// 重載 operator&
142     //unsigned int operator &()
143     //{
144     //    return static_cast<unsigned int>(head);
145     //}
146     size_type size()
147     {
148         return size_;
149     }
150     bool empty()
151     {
152         return size_ == 0;
153     }
154     value_type front()
155     {
156         return head->next->data;
157     }
158     value_type back()
159     {
160         return tail->next;
161     }
162     iterator begin()
163     {
164         return head->next;
165     }
166     iterator end()
167     {
168         return tail->next;
169     }
170     const_iterator begin() const
171     {
172         return head->next;
173     }
174     const_iterator end() const
175     {
176         return tail->next;
177     }
178     void push_back(value_type v)
179     {
180         PNode p = new Node;
181         if (p == 0)
182         {
183             exit(1);
184         }
185         p->data = v;
186         p->next = 0;
187         tail->next = p;
188         tail = p;
189         ++size_;
190     }
191     void push_front(value_type v)
192     {
193         PNode p = new Node;
194         if (p == 0)
195         {
196             exit(1);
197         }
198         p->data = v;
199         p->next = head->next;
200         head->next = p;
201         ++size_;
202     }
203     void pop_front()
204     {
205         PNode p = head->next;
206         head->next = head->next->next;
207         delete p;
208         --size_;
209     }
210     iterator insert(const iterator& iter, value_type v)
211     {
212         Pnode p = new PNode;
213         if (p == 0)
214         {
215             exit(1);
216         }
217         p->data = v;
218         PNode q = iter.getPNode();
219         p->next = q->next;
220         q->next = p;
221         return p;
222     }
223     void clear()
224     {
225         PNode p = head->next, q;
226         while (p)
227         {
228             q = p->next;
229             delete p;
230             p = q;
231         }
232         head->next = 0;
233         delete head;
234         size_ = 0;
235     }
236 };
237 
238 int main()
239 {
240     mylist<int> t;
241     for (int i = 0; i < 10++i)
242     {
243         t.push_back(i);
244     }
245     cout << t.size() << endl;
246     for (mylist<int>::iterator iter = t.begin(); iter != t.end(); ++iter)
247     {
248         cout << *iter << ' ';
249     }
250     cout << endl;
251 
252     mylist<int> t2(t);
253     cout << t2.size() << endl;
254     for (mylist<int>::iterator iter = t2.begin(); iter != t2.end(); ++iter)
255     {
256         cout << *iter << ' ';
257     }
258     cout << endl;
259 
260     mylist<int> t3;
261     cout << t3.size() << endl;
262     for (mylist<int>::iterator iter = t3.begin(); iter != t3.end(); ++iter)
263     {
264         cout << *iter << ' ';
265     }
266     cout << endl;
267     t3 = t2;
268     cout << t3.size() << endl;
269     for (mylist<int>::iterator iter = t3.begin(); iter != t3.end(); ++iter)
270     {
271         cout << *iter << ' ';
272     }
273     cout << endl;
274     //cout << &t << endl;
275     //cout << &t2 << endl;
276     //cout << t.head << endl;
277     //cout << t2.head << endl;
278 }
posted on 2011-04-24 01:04 unixfy 閱讀(343) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久全国免费视频| 亚洲人成欧美中文字幕| 国产精品乱码妇女bbbb| 欧美激情综合网| 免费亚洲一区二区| 欧美日韩高清在线观看| 欧美色中文字幕| 国产精品乱码一区二区三区| 国产精品久久久久婷婷| 午夜精品成人在线视频| 国产欧美精品| 精品动漫一区二区| 亚洲国产精品va在线观看黑人| 亚洲成人在线网站| 在线一区视频| 久久精品国产99国产精品| 久久久亚洲国产美女国产盗摄| 老司机精品视频网站| 亚洲欧洲精品天堂一级| 亚洲一区尤物| 免费日本视频一区| 国产精品免费观看在线| 国内精品一区二区| 宅男精品导航| 玖玖精品视频| 亚洲少妇诱惑| 蜜桃av久久久亚洲精品| 国产精品精品视频| 亚洲国产日韩美| 午夜影视日本亚洲欧洲精品| 欧美二区在线播放| 午夜精品理论片| 欧美日韩成人在线视频| 激情综合久久| 欧美在线免费观看亚洲| 亚洲精品资源| 欧美成人国产| 国产中文一区| 欧美一区观看| 一区二区三区国产精品| 美女脱光内衣内裤视频久久影院| 国产精品午夜在线观看| 一区二区日韩伦理片| 欧美国产一区二区| 久久精品二区| 国产主播一区二区三区四区| 亚洲免费在线| 一区二区三区欧美亚洲| 欧美精品亚洲| 亚洲人成在线播放网站岛国| 美脚丝袜一区二区三区在线观看| 亚洲一区免费看| 欧美午夜在线观看| 亚洲视频axxx| 一本色道久久88综合日韩精品| 欧美国产先锋| 亚洲欧洲日产国码二区| 老司机精品导航| 欧美在线免费| 国产亚洲一区在线播放| 欧美亚洲一区二区三区| 制服诱惑一区二区| 欧美网站在线| 亚洲欧美一区二区在线观看| 一本一本久久a久久精品综合妖精| 欧美阿v一级看视频| 最新日韩中文字幕| 亚洲区一区二| 国产一区二区三区高清播放| 亚洲乱码久久| 91久久精品一区二区别| 欧美v亚洲v综合ⅴ国产v| 亚洲激情成人| 亚洲日韩成人| 国产精品视频在线观看| 久久精品欧美日韩精品| 久久亚洲风情| 日韩午夜免费| 一区二区日本视频| 国产精品区二区三区日本| 欧美一区二区视频在线观看| 欧美一区二区在线看| 在线观看三级视频欧美| 亚洲国产日韩精品| 欧美日韩亚洲网| 久久gogo国模啪啪人体图| 久久亚洲高清| 亚洲视频成人| 久久精彩视频| 一区二区三区日韩精品| 亚洲免费在线观看| 亚洲精品1区2区| 亚洲一区一卡| 亚洲靠逼com| 午夜精品久久久久99热蜜桃导演| 伊人狠狠色j香婷婷综合| 亚洲精品影视| 国模一区二区三区| 亚洲精品综合| 雨宫琴音一区二区在线| 一片黄亚洲嫩模| 亚洲成人资源网| 亚洲自拍高清| 一本色道久久88精品综合| 午夜精品国产| 国产精品99久久久久久久vr| 欧美在线视频日韩| 亚洲一区二区不卡免费| 久久免费视频网站| 欧美一区二区免费观在线| 欧美国产日韩视频| 老司机免费视频一区二区| 国产精品久久久久久户外露出| 女人天堂亚洲aⅴ在线观看| 国产精品久久久久久久久动漫 | 欧美成人午夜激情视频| 亚洲综合国产| 欧美激情黄色片| 可以看av的网站久久看| 国产精品亚洲一区| 9国产精品视频| 亚洲卡通欧美制服中文| 久久午夜国产精品| 久久久精品五月天| 国产精品自拍三区| 一区二区毛片| 中文国产成人精品| 欧美极品欧美精品欧美视频| 蜜桃视频一区| 在线观看中文字幕亚洲| 激情小说另类小说亚洲欧美| 欧美一级电影久久| 欧美激情精品久久久久久大尺度 | 新67194成人永久网站| 欧美激情第10页| 欧美福利电影在线观看| 亚洲第一网站| 久久久之久亚州精品露出| 久久精品国产99国产精品澳门| 国产精品日本欧美一区二区三区| 亚洲免费av观看| 中文国产亚洲喷潮| 国产精品扒开腿爽爽爽视频| 在线亚洲观看| 欧美一区二区高清在线观看| 国产精品一区亚洲| 亚洲欧美精品中文字幕在线| 亚洲欧美在线一区| 国产欧美一区二区三区久久 | 欧美午夜视频在线| 亚洲视频免费| 欧美一区=区| 国内外成人在线视频| 久久精品水蜜桃av综合天堂| 久久午夜国产精品| 亚洲国内精品在线| 欧美日韩不卡在线| 午夜欧美大片免费观看| 久久尤物视频| 亚洲裸体俱乐部裸体舞表演av| 欧美高清视频| 亚洲视频碰碰| 久久久噜噜噜久久中文字幕色伊伊 | 欧美日本久久| 亚洲欧美日韩精品久久奇米色影视| 欧美在线亚洲在线| 亚洲国产日韩在线一区模特| 欧美精品日韩一区| 亚洲一区二区欧美| 免费的成人av| 一本大道久久a久久精品综合| 欧美视频中文在线看 | 亚洲国产精品久久久久秋霞蜜臀| 欧美韩日精品| 亚洲一线二线三线久久久| 毛片精品免费在线观看| 一区二区三区波多野结衣在线观看| 国产精品视频xxx| 美女精品自拍一二三四| a4yy欧美一区二区三区| 老牛影视一区二区三区| 99re热精品| 在线不卡亚洲| 国产精品亚洲综合色区韩国| 欧美岛国在线观看| 欧美在现视频| 亚洲视频一区在线| 91久久久久| 欧美sm视频| 欧美一区二区三区四区夜夜大片| 亚洲精品三级| 亚洲视频图片小说| 在线观看精品视频| 国产精品日韩在线播放| 欧美国产免费| 美女黄毛**国产精品啪啪| 欧美一区二区在线免费观看| 亚洲免费观看高清完整版在线观看熊 | 国产日产欧产精品推荐色 | 欧美一进一出视频|