map值是什么意思啊 如何給map的key值排序?
如何給map的key值排序?在C中,map是一種常見且易于使用的數(shù)據(jù)結構。映射是按鍵自動排序的,但有時我們需要按每個元素的值對映射進行排序。因為STL的sort函數(shù)不支持按值對地圖排序,所以我們只能考
如何給map的key值排序?
在C中,map是一種常見且易于使用的數(shù)據(jù)結構。映射是按鍵自動排序的,但有時我們需要按每個元素的值對映射進行排序。因為STL的sort函數(shù)不支持按值對地圖排序,所以我們只能考慮另一種方法。
這是一種非常方便的使用Multimap的方法。Multimap與map類似,每個元素分為兩部分:鍵和值。類似地,Multimap將根據(jù)鍵自動排序。區(qū)別在于map中的key不允許重復,而Multimap允許key重復。通過將映射中的鍵和值傳遞到Multimap,可以按值對映射進行排序。
代碼如下所示:
Map<char,int> CNT,Multimap<int,char>ucnt for(Map<char,int>::iterator itr=cnt.開始()它!= 控制端()itr){ucnt.插入(pair< int,char>(ITR->second,ITR->first))}
設計模式應該是適配器模式。
至于為什么要用map來實現(xiàn),我理解目的是用map的鍵來實現(xiàn)set的值不重復。
您可以看到HashSet的add方法使用了HashMap的put方法,它只是將值作為HashMap中的鍵
put的值直接定義了一個空對象