モーダルを閉じる工作HardwareHub ロゴ画像

工作HardwareHubは、ロボット工作や電子工作に関する情報やモノが行き交うコミュニティサイトです。さらに詳しく

利用規約プライバシーポリシー に同意したうえでログインしてください。

ハッシュ関連の用語整理 (C++をもう一度)

モーダルを閉じる

ステッカーを選択してください

お支払い手続きへ
モーダルを閉じる

お支払い内容をご確認ください

購入商品
」ステッカーの表示権
メッセージ
料金
(税込)
決済方法
GooglePayマーク
決済プラットフォーム
確認事項

利用規約をご確認のうえお支払いください

※カード情報はGoogleアカウント内に保存されます。本サイトやStripeには保存されません

※記事の執筆者は購入者のユーザー名を知ることができます

※購入後のキャンセルはできません

作成日作成日
2014/12/28
最終更新最終更新
2018/09/07
記事区分記事区分
一般公開

目次

    低レイヤーのプログラミングとOS開発が趣味。C言語を使っています。

    暗号技術で有名な MD5 や SHA-1, SHA-2 (SHA-256など) はハッシュ関数です。ハッシュ関数はある集合 A から別のある集合 B への写像関数のようなもので、集合 A の要素 a を入力として実行すると集合 B の要素 b が出力されます。このとき要素 b のことを要素 a のハッシュ値とよびます。また、集合 A の要素と集合 B の要素の対応表をハッシュ表とよびます。一般に集合 A をハッシュ関数に通すと、圧縮された集合 B が出力されます。つまり、集合 A の異なる a1 と a2 を入力すると集合 B の同じ値 b が出力されることがあります。

    二分探索木 (集合や連想配列) などのデータ構造とハッシュ関数を組み合せると、データ構造だけを利用してデータを管理する場合と比較して検索性を向上させることができます。これをハッシュ法とよびます。ハッシュ法におけるハッシュ関数には処理時間がかからないことが求められます。

    ハッシュ法の実装例

    #include <iostream>
    #include <map>
    using namespace std;
    
    class MyHash {
    public:
        static const size_t HASH_TBL_SIZE = 23;
        static size_t Get(const string& value);
    
    public:
        string& operator[](const string& key);
    
    private:
        map<string, string> m_hashTable[HASH_TBL_SIZE];
    };
    
    size_t MyHash::Get(const string& value) {
        size_t size = value.size();
        const unsigned char* p 
            = reinterpret_cast<const unsigned char*>(value.data());
        return (p[0] + p[size /2] + p[size - 1]) % HASH_TBL_SIZE;
    }
    
    string& MyHash::operator[](const string& key) {
        return m_hashTable[Get(key)][key];
    }
    
    int main() {
        MyHash h;
        h["one"] = "ichi";
        h["two"] = "ni";
        cout << h["one"] << endl; //=> ichi
        cout << h["two"] << endl; //=> ni
        return 0;
    }
    
    Likeボタン(off)0
    詳細設定を開く/閉じる
    アカウント プロフィール画像

    低レイヤーのプログラミングとOS開発が趣味。C言語を使っています。

    記事の執筆者にステッカーを贈る

    有益な情報に対するお礼として、またはコメント欄における質問への返答に対するお礼として、 記事の読者は、執筆者に有料のステッカーを贈ることができます。

    >>さらに詳しくステッカーを贈る
    ステッカーを贈る コンセプト画像

    Feedbacks

    Feedbacks コンセプト画像

      ログインするとコメントを投稿できます。

      ログインする

      関連記事