日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

关于C++中的unordered_map和unordered_set不能直接以pair作为键名的问题

發布時間:2025/3/8 c/c++ 61 豆豆
生活随笔 收集整理的這篇文章主要介紹了 关于C++中的unordered_map和unordered_set不能直接以pair作为键名的问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

關于C++中的unordered_map和unordered_set不能直接以pair作為鍵名的問題

在 C++ STL 中,不同于有序的 std::map 和 std::set 是基于紅黑樹實現的,std::unordered_map 和 std::unordered_set 是基于哈希實現的,在不要求容器內的鍵有序,僅要求查找效率較高時,哈希實現的后者時更為合適的,哈希表的運用也經常出現在各種算法題中。

但是,我們知道,既然是基于哈希實現的,那么就需要指定哈希函數。對于內置的數據類型如 int,float,char 等,STL 庫已經幫助我們內置了常用的哈希函數。因此通常,我們在使用這些數據類型組成的 unordered_map 和 unordered_set 可以不再指定哈希函數,直接用默認的。這在 unordered_map 的類模板定義中也可看到:

template < class Key, //容器中存儲元素的類型class Hash = hash<Key>, //確定元素存儲位置所用的哈希函數class Pred = equal_to<Key>, //判斷各個元素是否相等所用的函數class Alloc = allocator<Key> //指定分配器對象的類型> class unordered_set;

在這些參數重,只有第一個參數是沒有默認值的。也就是說,在我們創建 int 、char 等內置類型的 unordered_set 時只需要傳入存儲在容器中的類型即可。

但是,對于沒有默認的哈希函數的類型,如自定義的 class 類型,pair 類型等,我們就必須自己指定一個哈希函數。這也是為什么直接構建 pair 類型的 unordered_set 如 unordered_set<pair<int, int>> uset 會出現問題(不會在聲明時報錯,而是在 insert 等操作時)。

對于這種情況,我們只需要將上面的第二個參數:確定元素存儲位置所用的哈希函數,也在聲明時傳入就行了。關于哈希函數的選擇,不同的情景會有所不同。這里筆者給出一個最簡單的針對 pair 類型的哈希函數。

struct SimplePairHash {std::size_t operator()(const std::pair<int, int>& p) const {return p.first ^ p.second;} };

在聲明時直接將其傳入即可:

std::unordered_set<std::pair<int, int>, SimplePairHash> S; S.insert(std::make_pair(0, 1));

Ref :

https://stackoverflow.com/questions/21288345/unordered-set-of-pairs-compilation-error

https://blog.csdn.net/pineappleKID/article/details/108341064

總結

以上是生活随笔為你收集整理的关于C++中的unordered_map和unordered_set不能直接以pair作为键名的问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。