欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費電子書(shū)等14項超值服

開(kāi)通VIP
[C++] STL里面的map - Eric‘s Little Hut
STL里面的map并不是哈希表,這對于習慣了MFC里面CMap的人可能有點(diǎn)不習慣。STL里面的map僅僅是棵紅黑樹(shù)。
除非你對程序的效率毫不關(guān)心,否則你就應該使用stlex里面的hash_map代替stl里面的map。因為他們做著(zhù)非常類(lèi)似的工作,而且他們的調用方法幾乎一樣。

hash_map需要對key取hash值,我想這應該不會(huì )是問(wèn)題。我們在實(shí)際應用中,通常只會(huì )用數值、指針或者字符串作為key,這些東西都是很容易hash的。實(shí)際上,用object作為key反而容易出現問(wèn)題,大多數人并不鼓勵在C++里面用object做key。

說(shuō)遠一點(diǎn),C#里面倒是非常開(kāi)心的一直用object做著(zhù)哈希表的key,這是為什么呢?這是因為C#是一個(gè)單根體系,所有的class都是從System.Object派生出來(lái)的,而System.Object實(shí)現了GetHashCode方法。這迫使C#中所有的對象,要么采用基類(lèi)的GetHashCode方法,要么實(shí)現自己的GetHashCode方法。



Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=525824

[推薦本文] [點(diǎn)擊此處收藏本文]   發(fā)表于 2005年11月09日 10:16 AM

 
http://blog.vckbase.com/bruceteen/ 發(fā)表于2005-11-09 1:05 PM  IP: 221.6.3.*
當初制定CPP98時(shí),時(shí)間緊迫,要想知道為什么選用RB-Tree而不是hash的原因必須先了解RB-Tree和hash的差別:
a. RB-Tree的查找和刪除時(shí)間復雜度是log(o),而hash呢,快的時(shí)候是常數級,慢的時(shí)候(碰撞)也關(guān)系不大。
b. 插入:RB-Tree仍然是log(o),而hash快的時(shí)候同樣是常數級,但最慢的時(shí)候可能需要重新分配內存和重新構造hash。
結論是:
RB-Tree效率穩定,而hash在基于隨即統計上比RB-Tree要快。
所以:
a. 首先從需求上考慮到底使用哪個(gè)容器,比如某個(gè)用戶(hù)查詢(xún),用RB-Tree一萬(wàn)次,每次需要花費2秒;用hash,9999次每次花費1秒,但有一次需要花費10000秒。此時(shí),你應該選用哪個(gè)?雖然總體時(shí)間上還是hash快,但哪個(gè)花費了10000秒的用戶(hù)可不同意這種說(shuō)法。
b. 對于既可以使用RB-TREE又可以使用hash的情況下,要根據數據量,已經(jīng)這些數據的統計學(xué)特性來(lái)選擇相應的容器。

 
Eric 發(fā)表于2005-11-09 5:24 PM  IP: 218.109.35.*

RB-Tree未必總是效率穩定的。比如查找長(cháng)度1000的string key和查找長(cháng)度為1的string key的時(shí)候,RB tree顯然將由于string.compare的工作量差異而出現總體上的效率差異;而此時(shí)hash表反而可以表現出穩定的效率。
再者,tree中存放的具體內容,會(huì )影響每次string.compare的工作量,從而影響RB-Tree的總體效率。而hash表受具體內容的影響就比較小,因為hash表的compare次數比較少。

以上都是理論分析。在對程序效率有要求的實(shí)際應用中,我還沒(méi)遇到紅黑樹(shù)比哈希表更優(yōu)秀的情況。
能不能請樓上舉一個(gè)具體的例子呢?

PS:我承認我在邏輯上處于不利地位,因為我是要證明“命題總是成立”,而樓上只需要舉一個(gè)例子反證就可以了。不過(guò)我仍然對此躍躍欲試。
本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請點(diǎn)擊舉報。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
幾種常見(jiàn) 容器 比較和分析 hashmap, map, vector, list ...hash table
STL 筆記1
Hashtable 構造函數 ()的VB.NET例子
深入理解STL之RBTree
STL容器分類(lèi)
【轉】使用STL的hash_map要點(diǎn)
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導長(cháng)圖 關(guān)注 下載文章
綁定賬號成功
后續可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服

欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久