LC 981. Time Based Key-Value Store
Create a timebased key-value store class TimeMap, that supports two operations.
1. set(string key, string value, int timestamp)
- Stores the keyandvalue, along with the giventimestamp.
2. get(string key, int timestamp)
- Returns a value such that set(key, value, timestamp_prev)was called previously, withtimestamp_prev <= timestamp.
- If there are multiple such values, it returns the one with the largest timestamp_prev.
- If there are no values, it returns the empty string ("").
Runtime: 212 ms, faster than 55.01% of C++ online submissions for Time Based Key-Value Store.
Memory Usage: 57 MB, less than 100.00% of C++ online submissions for Time Based Key-Value Store.
class TimeMap { private: unordered_map<string, map<int, string>> mp; vector<int> tvec; public: /** Initialize your data structure here. */ TimeMap() {} void set(string key, string value, int timestamp) { mp[key][timestamp] = value; } string get(string key, int timestamp) { if(!mp.count(key)) return ""; if(mp[key].count(timestamp)) return mp[key][timestamp]; for(auto it = mp[key].rbegin(); it != mp[key].rend(); it++) { if(it->first > timestamp) continue; else { return it->second; } } return ""; } };
 
                     
                    
                 
                    
                 
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号