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

posts - 183,  comments - 10,  trackbacks - 0

最初想法來自于《編程珠璣》,下午實現了一下
不多說了,直接看代碼吧

  1 //
  2 //    HashTable
  3 //
  4 //    goonyangxiaofang(AT)163(DOT)com
  5 //    QQ: 五九一二四七八七六
  6 //
  7 
  8 #include <iostream>
  9 #include <string>
 10 
 11 #define MYTRACE(t, f) std::cout << #t": " << t << std::endl; if(f == 1) std::cin.get()
 12 #define PRINTNAME(name) std::cout << #name": " << std::endl
 13 
 14 template <typename Key, typename Data, unsigned int prime = 11>
 15 class HashTable
 16 {
 17     struct Node
 18     {
 19         Key   key;
 20         Data  data;
 21         Node* next;
 22         Node() : next(0) {}
 23         Node(const Key& k) : key(k), next(0) {}
 24         Node(const Key& k, const Data& d) : key(k), data(d), next(0) {}
 25         Node(const Key& k, const Data& d, const Node* p) : key(k), data(d), next(p) {}
 26         Node(const Node& n) : key(n.key), data(n.data), next(n.next) {}
 27         ~Node() {}
 28     };
 29     Node** table;
 30 private:
 31     unsigned int getKey(const Key& k)
 32     {
 33         unsigned int ret = 0;
 34         char* h = reinterpret_cast<char*>(const_cast<Key*>(&k));
 35         for (unsigned int i = 0; i < sizeof (Key); ++i)
 36         {
 37             ret += static_cast<unsigned int>(h[i]) * 10;
 38         }
 39         return ret % prime;
 40     }
 41 public:
 42     HashTable()
 43     {
 44         table = new Node*[prime];
 45         for (unsigned int i = 0; i < prime; ++i)
 46         {
 47             table[i] = 0;
 48         }
 49     }
 50     HashTable(const HashTable& ht)
 51     {
 52         table = new Node*[prime];
 53         for (unsigned int i = 0; i < prime; ++i)
 54         {
 55             table[i] = 0;
 56             Node** p = &(table[i]);
 57             Node*  q = ht.table[i];
 58             while (q)
 59             {
 60                 Node* r = new Node(q->key, q->data);
 61                 *= r;
 62                 p = &(r->next);
 63                 q = q->next;
 64             }
 65         }
 66     }
 67     HashTable& operator=(const HashTable& ht)
 68     {
 69         if (this != &ht)
 70         {
 71             clear();
 72             table = new Node*[prime];
 73             for (unsigned int i = 0; i < prime; ++i)
 74             {
 75                 table[i] = 0;
 76                 Node** p = &table[i];
 77                 Node*  q = ht.table[i];
 78                 while (q)
 79                 {
 80                     Node* r = new Node(q->key, q->data);
 81                     *= r;
 82                     p = &(r->next);
 83                     q = q->next;
 84                 }
 85             }
 86         }
 87         return * this;
 88     }
 89     bool find(const Key& k)
 90     {
 91         Node* p = table[getKey(k)];
 92         while (p)
 93         {
 94             if (k == p->key)
 95             {
 96                 return true;
 97             }
 98             p = p->next;
 99         }
100         return false;
101     }
102     bool insert(const Key& k, const Data& d)
103     {
104         if (find(k))
105         {
106             return true;
107         }
108         unsigned int key = getKey(k);
109         Node*& p = table[key];
110         Node* q = new Node(k, d);
111         if (q == 0)
112         {
113             return false;
114         }
115         q->next = p;
116         p = q;
117         return true;
118     }
119     bool insert(const Key& k)
120     {
121         if (find(k))
122         {
123             return true;
124         }
125         unsigned int key = getKey(k);
126         Node*& p = table[key];
127         Node* q = new Node(k);
128         if (q == 0)
129         {
130             return false;
131         }
132         q->next = p;
133         p = q;
134         return true;
135     }
136     Data& get(const Key& k)
137     {
138         Node* p = table[getKey(k)];
139         while (p)
140         {
141             if (k == p->key)
142             {
143                 return p->data;
144             }
145             p = p->next;
146         }
147         insert(k);
148         Data d;
149         return d;
150     }
151     const Data& operator[](const Key& k) const
152     {
153         Node* p = table[getKey(k)];
154         while (p)
155         {
156             if (k == p->key)
157             {
158                 return p->data;
159             }
160             p = p->next;
161         }
162         insert(k);
163         Data d;
164         return d;
165     }
166     Data& operator[](const Key& k)
167     {
168         Node* p = table[getKey(k)];
169         while (p)
170         {
171             if (k == p->key)
172             {
173                 return p->data;
174             }
175             p = p->next;
176         }
177         insert(k);
178         Data d;
179         return d;
180     }
181     bool empty()
182     {
183         for (unsigned int i = 0; i < prime; ++i)
184         {
185             if (table[i] != 0)
186             {
187                 return false;
188             }
189         }
190         return true;
191     }
192     void print()
193     {
194         std::cout << std::endl;
195         for (unsigned int i = 0; i < prime; ++i)
196         {
197             Node* p = table[i];
198             std::cout << i << "";
199             while (p)
200             {
201                 std::cout << "" << p->key << "" << p->data << " ) ";
202                 p = p->next;
203             }
204             std::cout << std::endl;
205         }
206         std::cout << std::endl;
207     }
208     void clear()
209     {
210         for (unsigned int i = 0; i < prime; ++i)
211         {
212             Node* p = table[i];
213             Node* q = p;
214             while (p)
215             {
216                 p = p->next;
217                 delete q;
218                 q = p;
219             }
220         }
221         delete [] table;
222     }
223     ~HashTable()
224     {
225         clear();
226     }
227 };
228 
229 int main()
230 {
231     HashTable<long, std::string> ht1;
232     for (long i = 0; i < 26++i)
233     {
234         std::string s;
235         s += 'A' + i;
236         ht1.insert(i, s);
237     }
238     PRINTNAME(ht1);
239     ht1.print();
240 
241     for (long i = 0; i < 26++i)
242     {
243         std::string s;
244         s += 'A' + i;
245         ht1.insert(i, s);
246     }
247     PRINTNAME(ht1);
248     ht1.print();
249 
250     HashTable<long, std::string> ht2(ht1);
251     PRINTNAME(ht2);
252     ht2.print();
253 
254     ht1[25= "xxxxxxxx";
255     ht1.print();
256     ht2.print();
257 
258     HashTable<long, std::string> ht3;
259     ht3 = ht1;
260     PRINTNAME(ht3);
261     ht3.print();
262     return 0;
263 }
posted on 2011-03-09 18:57 unixfy 閱讀(441) 評論(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>
            欧美日韩一区二区欧美激情| 亚洲精品日本| 精品动漫3d一区二区三区免费| 国产精品成人免费| 欧美午夜宅男影院| 国产偷国产偷精品高清尤物| 国产欧美一区二区三区国产幕精品| 国产精品日韩二区| 国产视频一区二区在线观看| 好看的av在线不卡观看| 亚洲韩国青草视频| 亚洲一区二区三区高清| 欧美中文字幕在线| 欧美黄色视屏| 亚洲自拍16p| 久久综合影音| 国产精品亚洲视频| 在线观看视频一区| 亚洲性感美女99在线| 另类激情亚洲| 一区二区三区国产精品| 久久精品国产成人| 欧美午夜美女看片| 亚洲国产综合在线看不卡| 欧美与欧洲交xxxx免费观看| 亚洲国产精品一区二区尤物区 | 亚洲免费成人| 欧美制服丝袜第一页| 欧美激情麻豆| 欧美一区激情视频在线观看| 欧美精品国产一区| 国产一区二区丝袜高跟鞋图片| 亚洲靠逼com| 久久综合激情| 亚洲欧美日韩一区二区在线| 欧美国产日本在线| 好看的亚洲午夜视频在线| 亚洲一区二区精品| 91久久视频| 麻豆成人在线播放| 激情一区二区| 久久激情综合| 亚洲制服少妇| 亚洲一区久久久| 国产亚洲精品7777| 在线天堂一区av电影| 欧美va亚洲va香蕉在线| 午夜精品久久久久久久99热浪潮| 欧美激情一区二区在线| 亚洲国产精品ⅴa在线观看 | 亚洲高清一区二区三区| 久久都是精品| 国产亚洲欧美中文| 久久福利一区| 午夜在线a亚洲v天堂网2018| 国产精品美女久久久浪潮软件| 宅男噜噜噜66一区二区66| 亚洲国产精品一区二区第一页| 欧美高潮视频| 在线一区欧美| 一区二区三区精品在线| 欧美日韩的一区二区| av不卡免费看| 一区二区三区蜜桃网| 欧美三级视频在线播放| 亚洲在线视频观看| 午夜亚洲福利| 伊人影院久久| 亚洲国产日本| 国产精品成人一区二区艾草| 亚洲欧美中文在线视频| 午夜精品久久久久99热蜜桃导演| 国产一区二区视频在线观看| 欧美大香线蕉线伊人久久国产精品| 欧美成人午夜视频| 亚洲一区二区三区中文字幕在线| 亚洲一区二区三| 国产在线拍偷自揄拍精品| 老司机午夜精品| 欧美激情一区二区三区| 午夜精品区一区二区三| 久久免费国产精品1| 日韩亚洲欧美高清| 亚洲欧美日韩一区二区三区在线| 在线观看日韩精品| 一本久久知道综合久久| 国产在线乱码一区二区三区| 亚洲激情影视| 国产丝袜一区二区| 最新日韩在线视频| 国产亚洲二区| 亚洲美女视频网| 国产亚洲欧美aaaa| 亚洲区一区二区三区| 国产日韩精品一区二区三区| 欧美激情a∨在线视频播放| 国产精品视频自拍| 亚洲二区视频在线| 国产综合欧美| 亚洲一区在线免费观看| 亚洲国产精品一区制服丝袜| 亚洲午夜免费福利视频| 91久久精品国产91久久| 香蕉乱码成人久久天堂爱免费| 欧美精品粉嫩高潮一区二区 | 欧美不卡在线| 国产精品国产一区二区| 欧美激情区在线播放| 国产午夜精品全部视频在线播放| 亚洲欧洲日产国码二区| 伊人久久av导航| 亚洲一区二区三区激情| 亚洲乱码一区二区| 另类亚洲自拍| 噜噜爱69成人精品| 国产精品一区二区三区免费观看| 亚洲黄色尤物视频| 亚洲第一久久影院| 久久国产精品久久w女人spa| 午夜精品一区二区三区在线 | 国产视频在线观看一区| 一区二区三区日韩欧美精品| 亚洲日韩中文字幕在线播放| 久久精品欧洲| 久久精品综合| 国产欧美日本| 西西人体一区二区| 欧美呦呦网站| 国产曰批免费观看久久久| 午夜国产欧美理论在线播放| 午夜视黄欧洲亚洲| 国产精品色在线| 亚洲男人第一网站| 久久av一区二区三区亚洲| 国产日韩一区二区三区在线播放| 中文在线不卡视频| 午夜在线一区| 国模一区二区三区| 久久国产精品毛片| 美女999久久久精品视频| 亚洲电影免费观看高清完整版在线观看 | 亚洲一区二区三区四区视频| 亚洲影院一区| 国产精品视频yy9299一区| 亚洲午夜影视影院在线观看| 亚洲欧美中文另类| 国产在线一区二区三区四区| 久久国产精品99国产精| 欧美/亚洲一区| 亚洲美女中出| 国产精品欧美一区二区三区奶水 | 亚洲成人资源网| 免费在线亚洲欧美| 亚洲剧情一区二区| 销魂美女一区二区三区视频在线| 久久精品国产99国产精品澳门| 在线观看欧美视频| 久久免费视频在线| 欧美成人午夜激情视频| 亚洲精品社区| 国产精品国产三级国产专播精品人| 亚洲一区二区动漫| 久久伊人免费视频| 日韩午夜三级在线| 国产欧美精品一区二区三区介绍 | 亚洲欧美中文在线视频| 国产自产在线视频一区| 欧美成人精精品一区二区频| 99国产精品久久久久老师| 欧美一区久久| 亚洲国产日韩精品| 国产精品任我爽爆在线播放| 久久裸体艺术| 一区二区三区视频在线| 老牛影视一区二区三区| 在线亚洲免费视频| 在线观看一区二区视频| 国产精品久久婷婷六月丁香| 老牛嫩草一区二区三区日本 | 欧美多人爱爱视频网站| 亚洲欧美在线看| 日韩天堂av| 精品99视频| 国产精品私拍pans大尺度在线| 看片网站欧美日韩| 亚洲女爱视频在线| 亚洲精选视频免费看| 女生裸体视频一区二区三区| 亚洲欧美制服另类日韩| 一区二区黄色| 亚洲看片一区| 亚洲国产专区校园欧美| 激情91久久| 国产亚洲欧美在线| 国产精品三区www17con| 国产精品www994| 欧美日韩午夜在线| 欧美精品久久一区| 欧美成人免费小视频| 久久免费精品视频|