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

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>
            一区二区三区四区精品| 亚洲电影免费在线| 免费在线视频一区| 久久久久国产精品厨房| 久久久亚洲高清| 女人色偷偷aa久久天堂| 欧美日韩视频在线一区二区 | 亚洲精品一级| 中文av一区二区| 久久精品91久久久久久再现| 你懂的一区二区| 欧美日韩国产影片| 国产欧美精品一区二区色综合| 国产综合色在线| 99在线热播精品免费99热| 亚洲视频电影在线| 久久精品免费电影| 亚洲国产精品成人综合色在线婷婷| 久久天堂成人| 91久久精品美女高潮| 亚洲欧美国产精品桃花| 六十路精品视频| 国产精品美女xx| 亚洲国产一区二区精品专区| 亚洲主播在线观看| 欧美freesex交免费视频| 野花国产精品入口| 久久成人一区二区| 国产精品v亚洲精品v日韩精品| 一区二区视频欧美| 欧美电影免费| 狠狠v欧美v日韩v亚洲ⅴ| 在线视频亚洲欧美| 亚洲国产毛片完整版| 欧美有码在线视频| 亚洲精品视频二区| 久久综合色播五月| 国产亚洲人成a一在线v站| 一区二区三区鲁丝不卡| 牛牛影视久久网| 性做久久久久久久久| 欧美揉bbbbb揉bbbbb| 亚洲激情亚洲| 美女黄毛**国产精品啪啪| 亚洲欧美日韩综合国产aⅴ | 一区二区三区在线不卡| 午夜老司机精品| 一区二区三区精品视频在线观看| 欧美成人69| 亚洲国产精品电影在线观看| 久久久免费精品| 欧美一二区视频| 国产酒店精品激情| 亚洲欧美中日韩| 亚洲天堂成人在线观看| 欧美日韩中字| 亚洲一区二区三区色| 亚洲精品综合| 欧美日韩国产123区| 99热这里只有精品8| 亚洲欧洲日本国产| 欧美裸体一区二区三区| 亚洲精品日韩综合观看成人91| 裸体一区二区| 快播亚洲色图| 亚洲承认在线| 男女视频一区二区| 欧美88av| 9久re热视频在线精品| 亚洲精品一区二区三区蜜桃久| 欧美精品videossex性护士| 亚洲人成网站精品片在线观看| 欧美激情小视频| 欧美日韩国产免费| 亚洲综合国产激情另类一区| 久久精品盗摄| 久久免费黄色| 亚洲精品久久在线| 亚洲视频999| 国产在线视频欧美| 欧美激情第8页| 欧美日韩一二三四五区| 午夜精品成人在线| 久久精品免费电影| 日韩视频免费观看高清完整版| 日韩视频在线观看| 国产日韩视频| 欧美大胆成人| 在线亚洲免费| 精品动漫3d一区二区三区免费| 久久色在线播放| 玖玖综合伊人| 一区二区免费在线视频| 国产精品99久久不卡二区| 国产精品系列在线| 欧美www视频| 欧美四级在线观看| 久久野战av| 欧美视频亚洲视频| 久久中文精品| 欧美视频日韩视频| 美女图片一区二区| 欧美日韩午夜| 蜜桃精品一区二区三区 | 亚洲欧美一区二区三区久久 | 亚洲精品一区二区三区福利| 国产精品国产三级欧美二区 | 欧美日韩综合精品| 久久久久综合一区二区三区| 亚洲精选91| 欧美日韩一区免费| 久久中文欧美| 欧美体内she精视频| 欧美激情综合| 国产深夜精品| 最新中文字幕亚洲| 国产日韩欧美一区在线| 亚洲国产老妈| 伊人成年综合电影网| 亚洲视频一区| 一本综合久久| 久久综合中文字幕| 久久久国产精品一区二区三区| 欧美日韩亚洲一区二区| 欧美激情一区二区三区全黄 | 亚洲国产女人aaa毛片在线| 亚洲欧美一区二区三区极速播放| 亚洲日本中文字幕| 免费观看一区| 欧美18av| 亚洲国产精品成人久久综合一区| 亚洲欧美日韩电影| 亚洲专区一区| 欧美午夜视频在线| 日韩视频在线一区二区| 日韩一级黄色片| 欧美国产一区二区| 亚洲激情成人网| 亚洲精品在线免费| 欧美国产欧美综合 | 美女主播视频一区| 美女网站久久| 亚洲第一福利社区| 另类激情亚洲| 免费在线国产精品| 亚洲国产黄色| 免费不卡在线观看| 亚洲激情小视频| 99精品久久久| 欧美日韩在线播| 亚洲午夜一级| 久久精品国产免费| 激情欧美日韩一区| 女主播福利一区| 亚洲毛片在线观看| 性欧美暴力猛交69hd| 国产综合18久久久久久| 久久久久青草大香线综合精品| 欧美18av| 亚洲视频在线看| 国产美女一区| 蜜臀a∨国产成人精品| 99精品免费| 久久理论片午夜琪琪电影网| 亚洲国产成人精品女人久久久 | 欧美顶级少妇做爰| 日韩午夜激情av| 国产精品青草久久久久福利99| 欧美在线视频网站| 亚洲国产成人一区| 亚洲欧美伊人| 亚洲国产精品成人va在线观看| 欧美三日本三级少妇三2023| 欧美亚洲日本一区| 亚洲精品视频二区| 久久久久久久久久久成人| 亚洲区在线播放| 国产精品视频不卡| 欧美成人dvd在线视频| 亚洲小少妇裸体bbw| 欧美成人福利视频| 香蕉乱码成人久久天堂爱免费| 1024日韩| 国产日本欧美一区二区| 蘑菇福利视频一区播放| 亚洲欧美自拍偷拍| 亚洲欧洲日本专区| 久久综合伊人77777| 亚洲综合激情| 日韩亚洲欧美精品| 亚洲电影一级黄| 国产啪精品视频| 欧美日韩国产三区| 老司机精品视频一区二区三区| 亚洲一区三区电影在线观看| 亚洲国产成人精品女人久久久| 久久手机免费观看| 久久精品国产99国产精品| 亚洲一级在线观看| 99天天综合性|