• HDU 1880 Hash table with chaining


    HDU 1880

    #include <bits/stdc++.h>
    #define DBG(x) cerr << #x << " = " << x << endl
    
    using namespace std;
    typedef long long LL;
    
    const unsigned int KEY = 137;
    const int BUCKET_NUM = 120000;
    
    struct Hash {
        vector<pair<string, string>> h[BUCKET_NUM];
    
        unsigned int get_hash(const string &s) {
            unsigned int hs = 0;
            for (auto c : s)
                hs = (hs * KEY + c) % BUCKET_NUM;
            return hs;
        }
    
        void insert(const string &k, const string &v) {
            unsigned int hs = get_hash(k);
            h[hs].push_back(make_pair(k, v));
        }
    
        string *get(const string &key) {
            unsigned int hs = get_hash(key);
            for (auto &kv : h[hs]) {
                if (kv.first == key)
                    return &kv.second;
            }
            return nullptr;
        }
    } key2val, val2key;
    
    pair<string, string> get_kv(const string &str) {
        unsigned long pos = 0;
        for (int i = 0; i < str.size(); i++) {
            if (str[i] == ']') {
                pos = i;
                break;
            }
        }
        auto k = str.substr(1, pos - 1);
        auto v = str.substr(pos + 2, str.size() - pos - 2);
        return make_pair(k, v);
    }
    
    int main(int argc, char **argv) {
        ios::sync_with_stdio(false);
        string s;
        while (true) {
            getline(cin, s);
            if (s == "@END@") break;
            auto kv = get_kv(s);
            key2val.insert(kv.first, kv.second);
            val2key.insert(kv.second, kv.first);
        }
        int n;
        cin >> n;
        cin.get();
        for (int i = 0; i < n; i++) {
            getline(cin, s);
            if (s[0] == '[') {
                auto val = key2val.get(s.substr(1, s.size() - 2));
                if (val == nullptr) {
                    cout << "what?" << "
    ";
                } else {
                    cout << *val << "
    ";
                }
            } else {
                auto key = val2key.get(s);
                if (key == nullptr) {
                    cout << "what?" << "
    ";
                } else {
                    cout << *key << "
    ";
                }
            }
        }
        return 0;
    }
    
    /**
    [expelliarmus] the disarming charm
    [rictusempra] send a jet of silver light to hit the enemy
    [tarantallegra] control the movement of one's legs
    [serpensortia] shoot a snake out of the end of one's wand
    [lumos] light the wand
    [obliviate] the memory charm
    [expecto patronum] send a Patronus to the dementors
    [accio] the summoning charm
    @END@
    4
    [lumos]
    the summoning charm
    [arha]
    take me to the sky
    
    light the wand
    accio
    what?
    what?
    */
    
  • 相关阅读:
    jenkins+maven+svn的自动化部署
    python+selenium遇到鼠标悬停不成功可以使用js进行操作
    robot framework环境搭建
    selenium+python定位元素方法
    selenium+python元素操作
    selenium+python等待时间
    selenium+python浏览器窗口的切换
    jmeter学习(七)连接mysql 数据库
    jmeter学习(六)集合点和关联
    jmeter学习(五)参数化
  • 原文地址:https://www.cnblogs.com/ToRapture/p/11904084.html
Copyright © 2020-2023  润新知