自動(dòng)獲得map里key類型 如何給map的key值排序?
如何給map的key值排序?在C中,map是一種常見且易于使用的數(shù)據(jù)結(jié)構(gòu)。映射是按鍵自動(dòng)排序的,但有時(shí)我們需要按每個(gè)元素的值對(duì)映射進(jìn)行排序。因?yàn)镾TL的sort函數(shù)不支持按值對(duì)地圖排序,所以我們只能考
如何給map的key值排序?
在C中,map是一種常見且易于使用的數(shù)據(jù)結(jié)構(gòu)。映射是按鍵自動(dòng)排序的,但有時(shí)我們需要按每個(gè)元素的值對(duì)映射進(jìn)行排序。因?yàn)镾TL的sort函數(shù)不支持按值對(duì)地圖排序,所以我們只能考慮另一種方法。
這是一種非常方便的使用Multimap的方法。Multimap與map類似,每個(gè)元素分為兩部分:鍵和值。類似地,Multimap將根據(jù)鍵自動(dòng)排序。區(qū)別在于map中的key不允許重復(fù),而Multimap允許key重復(fù)。通過將映射中的鍵和值傳遞到Multimap,可以按值對(duì)映射進(jìn)行排序。
代碼如下所示:
Map<char,int> CNT,Multimap<int,char>ucnt for(Map<char,int>::iterator itr=cnt.開始()它!= 控制端()itr){ucnt.插入(pair< int,char>(ITR-> second,ITR-> first))}
LinkedHashMap中有一個(gè)模擬的“雙向循環(huán)列表”,用于保存條目的插入順序。我也可以用這個(gè)方法保存插入時(shí)鍵和值的順序。它暫定名為orderedhashmap。主代碼是從LinkedHashMap復(fù)制的。它還維護(hù)兩個(gè)模擬的“雙向循環(huán)鏈表”:keyheader和valueheader,保持鍵或值從小到大的順序。當(dāng)一個(gè)元素被放入時(shí),除了將它存儲(chǔ)在hash bucket中之外,還應(yīng)該根據(jù)鍵的大小將它插入key header中,并根據(jù)值的順序?qū)⑺迦雟alue header中。如果您想輸出,您可以從這兩個(gè)“頭指針”向前或向后迭代,以獲得鍵或值的有序條目。(可以實(shí)現(xiàn)正負(fù)順序的鍵和值的輸出,只比較數(shù)值型,如果不是數(shù)值型,可以按HashMap正常處理)。下面是測(cè)試結(jié)果:值按相反順序輸出java代碼orderhashmap