91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++標準庫Hash函數解析

發布時間:2024-11-20 09:41:30 來源:億速云 閱讀:79 作者:小樊 欄目:編程語言

C++標準庫中的<functional>頭文件提供了一些哈希函數,如std::hash,用于為不同類型的數據生成哈希值。這些哈希函數在算法、數據結構(如unordered_map和unordered_set)以及需要哈希值的場景中非常有用。

std::hash是一個模板類,可以接受一個類型參數,并提供一個靜態成員函數operator(),該函數返回一個std::size_t類型的哈希值。默認情況下,std::hash為整數類型、浮點類型和指針類型提供了實現。對于自定義類型,你可以通過特化std::hash來提供自己的哈希函數實現。

以下是一些使用std::hash的示例:

#include <iostream>
#include <functional>
#include <string>
#include <unordered_map>

int main() {
    // 使用默認的std::hash實現
    std::size_t hash1 = std::hash<int>{}(42);
    std::cout << "Hash of 42: " << hash1 << std::endl;

    std::size_t hash2 = std::hash<std::string>{}("hello");
    std::cout << "Hash of 'hello': " << hash2 << std::endl;

    // 使用自定義類型的std::hash實現
    struct MyType {
        int x;
        float y;
    };

    namespace std {
        template <>
        struct hash<MyType> {
            std::size_t operator()(const MyType& obj) const {
                std::size_t h1 = std::hash<int>{}(obj.x);
                std::size_t h2 = std::hash<float>{}(obj.y);
                return h1 ^ (h2 << 1); // 簡單的哈希組合
            }
        };
    }

    MyType obj = {42, 3.14f};
    std::size_t hash3 = std::hash<MyType>{}(obj);
    std::cout << "Hash of MyType: " << hash3 << std::endl;

    // 使用std::unordered_map
    std::unordered_map<std::string, int> my_map;
    my_map["apple"] = 1;
    my_map["banana"] = 2;

    return 0;
}

在這個示例中,我們首先使用默認的std::hash實現為整數和字符串生成哈希值。然后,我們為自定義類型MyType特化了std::hash,為其提供了自己的哈希函數實現。最后,我們展示了如何使用std::unordered_map,它依賴于std::hash來生成哈希值并存儲和檢索鍵值對。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

c++
AI

临湘市| 吕梁市| 溧水县| 安顺市| 泊头市| 临汾市| 晋州市| 阿拉善盟| 高碑店市| 忻州市| 曲靖市| 钦州市| 德清县| 江安县| 兖州市| 阿拉善左旗| 天峨县| 宣化县| 阳信县| 聂荣县| 三河市| 平潭县| 都江堰市| 讷河市| 建瓯市| 枣阳市| 高雄市| 仪征市| 德化县| 连江县| 青浦区| 勃利县| 交口县| 新巴尔虎右旗| 兖州市| 锦屏县| 临澧县| 福清市| 沧源| 尼玛县| 梅河口市|