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

posts - 183,  comments - 10,  trackbacks - 0

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

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

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

  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)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            国产精品老牛| 亚洲一区免费视频| 久久夜色精品国产| 中文av一区二区| 亚洲国产精品久久久| 久久国产日韩欧美| 欧美gay视频| 久久www免费人成看片高清| 中文一区字幕| 亚洲在线免费观看| 亚洲一区国产视频| 亚洲一区二区三区免费视频| 中文日韩在线视频| 亚洲自拍偷拍福利| 亚洲一区一卡| 欧美一级在线亚洲天堂| 欧美在线不卡视频| 久久精品国产免费| 欧美77777| 麻豆九一精品爱看视频在线观看免费| 久久久久久久久久看片| 欧美大秀在线观看| 国产精品第13页| 国产婷婷精品| 亚洲第一综合天堂另类专| 国内免费精品永久在线视频| 狠狠爱综合网| 日韩视频在线免费| 亚洲一区二区三区在线视频| 午夜久久一区| 久久尤物视频| 久久精品九九| 欧美高清影院| 午夜精品福利一区二区三区av | 久久嫩草精品久久久精品| 欧美一级久久久| 久久久精品动漫| 欧美日韩国产123| 国产精品久久国产精麻豆99网站| 欧美成年人网站| 欧美激情在线观看| 亚洲综合视频网| 午夜视频精品| 亚洲精品你懂的| 亚洲日本va午夜在线影院| 亚洲精品国产精品国自产观看| 樱花yy私人影院亚洲| 国产欧美一区二区三区久久人妖| 国产午夜精品久久久久久久| 国产情侣一区| 亚洲高清久久| 一本色道久久综合亚洲精品不| 亚洲精品日韩激情在线电影| 亚洲国产日韩在线| 亚洲性感美女99在线| 亚洲综合不卡| 久久久久久69| 欧美激情性爽国产精品17p| 亚洲国产精品成人| 日韩一区二区福利| 欧美xxx成人| 99热在这里有精品免费| 影音先锋一区| 亚洲一卡久久| 久久天天躁狠狠躁夜夜爽蜜月| 亚洲国产精品成人va在线观看| 欧美成人午夜| 亚洲视频在线观看| 久久婷婷av| 欧美大片免费久久精品三p | 亚洲精品三级| 亚洲性视频网站| 久久久久久有精品国产| 欧美大尺度在线观看| 国产精品久久久久久亚洲调教| 亚洲精品美女在线观看播放| 欧美a级一区| 一本综合精品| 久久香蕉国产线看观看av| 欧美成人国产一区二区| 国产精品美女午夜av| 亚洲欧洲精品一区二区| 欧美一级欧美一级在线播放| 欧美成人免费一级人片100| 99re6热在线精品视频播放速度| 午夜精品久久久久久久久| 欧美国产日韩精品| 欧美不卡高清| 欧美经典一区二区| 欧美在线视频一区| 欧美二区在线看| 欧美精品综合| 国产欧美精品一区二区三区介绍| 伊人激情综合| 午夜性色一区二区三区免费视频 | 在线欧美不卡| 亚洲欧美日韩国产一区二区| 亚洲国产视频一区| 久久精品一本久久99精品| 国产精品另类一区| 99re热这里只有精品视频| 媚黑女一区二区| 欧美黑人在线播放| 午夜国产精品视频免费体验区| 一区视频在线看| 免费一级欧美片在线观看| 欧美一区二区三区四区高清| 国产乱码精品1区2区3区| 亚洲网在线观看| 99精品国产一区二区青青牛奶| 欧美极品在线视频| 一区二区三区久久| 亚洲精品在线观看免费| 欧美国产视频在线| 一二美女精品欧洲| 亚洲综合色噜噜狠狠| 亚洲第一在线| 欧美韩国日本一区| 一本色道久久综合| 一区二区三区精品在线| 欧美三级在线播放| 欧美一区二区视频在线| 欧美专区亚洲专区| 在线视频国内自拍亚洲视频| 男人的天堂成人在线| 男男成人高潮片免费网站| 亚洲片国产一区一级在线观看| 亚洲高清在线播放| 欧美国产先锋| 国产亚洲午夜高清国产拍精品| 亚洲欧美视频在线| 亚洲精品视频在线播放| 亚洲一区二区av电影| 国产精品免费在线| 老色批av在线精品| 99精品国产在热久久下载| 国产精品综合久久久| 久久亚洲不卡| 欧美精品激情在线观看| 99热这里只有成人精品国产| 在线一区二区三区四区| 国产一区二区成人| 亚洲激情六月丁香| 国产欧美日韩麻豆91| 嫩草影视亚洲| 国产精品久久久久9999吃药| 久久久久久久999精品视频| 欧美成人精品一区二区三区| 亚洲午夜精品久久| 亚洲国产精品女人久久久| 欧美午夜免费电影| 免费观看日韩| 国产精品户外野外| 欧美jizz19hd性欧美| 欧美视频网址| 美女任你摸久久| 国产精品国色综合久久| 欧美激情第六页| 国产欧美精品一区| a4yy欧美一区二区三区| 欧美高清一区二区| 国产精品久久久久婷婷| 久久精品国产96久久久香蕉| 欧美区一区二区三区| 久久精品99久久香蕉国产色戒| 亚洲国产欧美日韩精品| 国产精品爽爽爽| 日韩一级精品视频在线观看| 亚洲成色www久久网站| 久久女同互慰一区二区三区| 欧美日韩在线免费视频| 欧美激情第4页| 欧美电影在线免费观看网站| 亚洲精品小视频| 亚洲韩国一区二区三区| 欧美在线观看你懂的| 先锋影音久久久| 国产精品久久9| 日韩一区二区高清| 亚洲人成网站色ww在线| 久久久亚洲人| 欧美韩国在线| 国产人成一区二区三区影院| 久久亚洲春色中文字幕| 久久尤物电影视频在线观看| 好吊日精品视频| 久久精品99| 久久精品国产久精国产爱| 国产精品日日摸夜夜添夜夜av | 久久精品亚洲一区| 国产精品videosex极品| 亚洲精品乱码久久久久久蜜桃麻豆| 亚洲电影在线| 欧美 日韩 国产在线| 久久躁日日躁aaaaxxxx| 欧美在线高清视频| 99riav久久精品riav| 久热精品在线视频| 亚洲欧美日韩一区二区在线| 国产精品成人va在线观看|