我正在基于LeetCode练习实现LRU缓存,但是以下代码无法编译
using namespace std;
class LRUCache {
private:
list<int> data;
unordered_map<int, list<int>::iterator&> keys_to_data;
void update_recency(int key, list<int>::iterator& it) {
data.erase(it);
data.push_front(key);
keys_to_data[key]; // issue here
}
public:
LRUCache(int capacity) {
}
int get(int key) {
int value = -1;
auto value_it = keys_to_data.find(key);
if(value_it != keys_to_data.end()) {
value = *(value_it->second);
update_recency(key, value_it->second);
}
return value;
}
void put(int key, int value) {
}
};
/ Library / Developer / CommandLineTools / usr / include / c ++ / v1 / tuple:1360:7:错误:对类型'std :: __ 1 :: __ list_iterator'的引用需要初始化程序 秒(_VSTD :: forward <_Args2>(_ VSTD :: get <_I2>(__ second_args))...) ^
...巨大的堆栈跟踪...
/Users/Paul/Desktop/int/main.cpp:17:21:注意:在实例化成员函数'std :: __ 1 :: unordered_map&,std :: __ 1 :: hash,std :: __ 1: :equal_to,std :: __ 1 :: allocator&>>> :: operator []'在这里要求 keys_to_data [key];
答案 0 :(得分:3)
您不能将参考作为值存储在地图中
unordered_map<int, list<int>::iterator&>
由于引用是不可分配的。
答案 1 :(得分:0)
存储迭代器,而不是对迭代器的引用
unordered_map :: iterator> keys_to_data;