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

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| 欧美日韩一二三区| 国产精品激情偷乱一区二区∴| 久久久久国内| 久久久亚洲人| 蜜臀av一级做a爰片久久| 男女激情视频一区| 午夜精品久久久99热福利| 国产精品视频第一区| 欧美日韩一区二区在线观看视频| 欧美日韩综合精品| 国产伦理一区| 亚洲人午夜精品免费| 亚洲女性裸体视频| 久久在线免费视频| 亚洲人成在线播放| 亚洲视频在线观看视频| 亚洲一二三级电影| 久久精品一区二区国产| 欧美另类在线播放| 国产视频在线一区二区| 亚洲人成人77777线观看| 亚洲午夜精品在线| 免费观看欧美在线视频的网站| 亚洲人成网站在线观看播放| 欧美一区二区三区免费观看视频| 麻豆久久婷婷| 国产亚洲一区二区三区| 亚洲黄色一区| 久久福利影视| 99精品欧美一区二区三区综合在线 | 亚洲欧洲三级| 久久国产精品久久精品国产 | 羞羞答答国产精品www一本| 欧美国产激情二区三区| 国产视频精品va久久久久久| 亚洲精选一区二区| 久久亚洲精品一区| 亚洲欧美视频在线观看视频| 欧美日韩另类视频| 亚洲精品在线视频| 欧美 日韩 国产一区二区在线视频| 亚洲性xxxx| 欧美视频中文字幕在线| 日韩亚洲精品视频| 亚洲第一狼人社区| 久久亚洲春色中文字幕久久久| 国产精品综合久久久| 亚洲一区二区三区视频| 亚洲免费观看| 欧美日本一道本| 艳妇臀荡乳欲伦亚洲一区| 欧美激情中文不卡| 你懂的国产精品永久在线| 激情久久久久| 另类激情亚洲| 亚洲国产精品va在看黑人| 美日韩精品视频免费看| 国产农村妇女精品一二区| 激情婷婷久久| 亚洲综合视频1区| 亚洲香蕉视频| 国产精品天天摸av网| 久久久另类综合| 美女日韩在线中文字幕| 中日韩视频在线观看| 亚洲天堂久久| 亚洲欧美视频一区二区三区| 最新国产拍偷乱拍精品| 免费观看30秒视频久久| 91久久久一线二线三线品牌| 亚洲电影免费| 欧美一区二区三区免费视| 欧美在线国产精品| 91久久在线播放| 一区二区久久久久| 国产精品99久久久久久有的能看| 亚洲人成精品久久久久| 国产精品久久一卡二卡| 你懂的成人av| 欧美日韩中文精品| 日韩视频国产视频| 亚洲第一综合天堂另类专| 中文精品视频一区二区在线观看| 好看的日韩视频| 亚洲与欧洲av电影| 一区二区三区免费网站| 欧美激情aⅴ一区二区三区| 亚洲一区二区三区在线看 | 亚洲黄色成人| 国产午夜精品视频免费不卡69堂| 小黄鸭视频精品导航| 欧美在线免费视频| 久久久噜噜噜久久中文字免| 亚洲精品系列| 亚洲一区二区三区精品动漫| 伊人激情综合| 亚洲欧美国产三级| 欧美一区二区三区视频免费| 欧美一区二区精品在线| 9i看片成人免费高清| 麻豆成人精品| 亚洲国产成人精品女人久久久 | 欧美一区二区观看视频| 欧美尤物一区| 欧美激情一区二区在线 | 亚洲欧美一区二区原创| 香蕉视频成人在线观看| 在线播放豆国产99亚洲| 夜夜夜精品看看| 麻豆精品传媒视频| 亚洲天堂av图片| 免费观看国产成人| 韩国v欧美v日本v亚洲v| 亚洲欧美中日韩| 亚洲伦理网站| 欧美激情视频在线播放| 亚洲国产美女| 一本一本大道香蕉久在线精品| 99国产精品视频免费观看一公开| 欧美高清视频在线| 国产毛片久久| 欧美在线free| 亚洲一区二区三区精品在线 | 麻豆国产精品777777在线| 99热免费精品在线观看| 欧美国产日韩二区| 亚洲国产精品成人久久综合一区| 欧美一区二区三区四区在线观看 | 日韩一区二区精品视频| 久久国产婷婷国产香蕉| 亚洲亚洲精品在线观看| 国产精品实拍| 久久精品国产精品亚洲精品| 欧美亚洲视频一区二区| 国产精品视频自拍| 亚洲一区二区视频在线| 一本色道久久88亚洲综合88| 欧美三级在线视频| 欧美在线免费播放| 久久精品国产欧美亚洲人人爽| 国产午夜久久| 亚洲精华国产欧美| 欧美连裤袜在线视频| 亚洲欧美中文日韩v在线观看| 亚洲欧美激情视频| 亚洲精品乱码久久久久久蜜桃91| 亚洲美女色禁图| 国模私拍一区二区三区| 亚洲人成7777| 亚洲丰满在线| 香港久久久电影| 亚洲午夜伦理| 亚洲区中文字幕| 午夜国产不卡在线观看视频| 久久精品亚洲一区二区| 久久精品日韩一区二区三区| 麻豆精品视频在线观看视频| 欧美日韩亚洲一区二区三区在线观看 | 亚洲欧洲日韩在线| 亚洲国产一成人久久精品| 欧美福利精品| 亚洲天堂网在线观看| 久久精品久久综合| 亚洲激情综合| 国产精品捆绑调教| 久久精品一区二区| 一区二区三区四区精品| 久久免费国产精品1| 日韩视频―中文字幕| 国产欧美一区二区三区久久| 久久天天狠狠| 99成人在线| 免费在线一区二区| 亚洲尤物视频网| 欧美日韩黄色大片| 欧美大色视频| 亚洲资源av| 黄色日韩在线| 欧美日韩国产天堂| 欧美在线观看网址综合| 亚洲精品久久久久久久久| 欧美一区二区三区四区视频| 91久久精品一区二区三区| 国产精自产拍久久久久久蜜| 欧美成人免费在线| 久久国内精品视频| 在线视频一区观看| 亚洲国产精品va在线观看黑人| 欧美在线观看网址综合| 一区二区欧美视频| 亚洲黄色成人久久久| 极品少妇一区二区| 国产欧美精品在线观看| 欧美三级午夜理伦三级中文幕| 欧美成人在线免费视频| 久久久久久噜噜噜久久久精品 | 免费观看成人|