LEetCode 460. LFU 캐 시 (해시 더 블 링크)
18268 단어 LeetCode
(LFU) 캐 시 를 가장 자주 사용 하지 않 는 데이터 구 조 를 설계 하고 구현 합 니 다.다음 동작 을 지원 해 야 합 니 다: get 과 put.
get(key)
- 키 가 캐 시 에 존재 하면 키 의 값 (항상 정수) 을 가 져 옵 니 다. 그렇지 않 으 면 - 1 을 되 돌려 줍 니 다.put(key, value)
- 키 가 존재 하지 않 으 면 값 을 설정 하거나 삽입 하 십시오.진급: O (1) 시간 복잡 도 에서 두 가지 조작 을 수행 할 수 있 습 니까?
:
LFUCache cache = new LFUCache( 2 /* capacity ( ) */ );
cache.put(1, 1);
cache.put(2, 2);
cache.get(1); // 1
cache.put(3, 3); // key 2
cache.get(2); // -1 ( key 2)
cache.get(3); // 3
cache.put(4, 4); // key 1
cache.get(1); // -1 ( key 1)
cache.get(3); // 3
cache.get(4); // 4
출처: 스냅 백 (LeetCode) 링크:https://leetcode-cn.com/problems/lfu-cache 저작권 은 인터넷 에 귀속 된다.상업 전 재 는 정부 에 연락 하여 권한 을 부여 해 주 십시오. 비 상업 전 재 는 출처 를 밝 혀 주 십시오.
2. 문제 풀이
class node{
public:
int k, v, f;
node(int key, int val, int freq):k(key),v(val),f(freq){}
};
class LFUCache {
unordered_map<int, list<node>::iterator> kPos;//key
unordered_map<int, list<node>> freq_list;// ,
int cap;
int minfreq;//
int size;
public:
LFUCache(int capacity) {
cap = capacity;
minfreq = 0;
size = 0;
}
int get(int key) {
if(kPos.find(key)==kPos.end())
return -1;
auto it = kPos[key];//
int f = it->f;
int v = it->v;
if(f == minfreq && freq_list[f].size() == 1)
minfreq++;// 1 , , +1
freq_list[f].erase(it);//
freq_list[++f].push_front(node(key,v,f));//
kPos[key] = freq_list[f].begin();//
return v;
}
void put(int key, int value) {
if(kPos.find(key)!=kPos.end())
{ // key
auto it = kPos[key];
int f = it->f;
if(f == minfreq && freq_list[f].size()==1)
minfreq++;
freq_list[f].erase(it);
freq_list[++f].push_front(node(key,value,f));
kPos[key] = freq_list[f].begin();
}
else if(size < cap)// key,
{
minfreq = 1;// 1
freq_list[minfreq].push_front(node(key,value,1));
kPos[key] = freq_list[1].begin();
size++;
}
else if(cap != 0 && size == cap)// key, , 0
{
auto Node = freq_list[minfreq].back();
int k = Node.k;
freq_list[minfreq].pop_back();//
kPos.erase(k);// key
size--;
put(key, value);
}
}
};
228 ms 40 MB
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
python 문자열 입력으로 모든 유효한 IP 주소 생성(LeetCode 93번 문제)이 문제의 공식 난이도는 Medium으로 좋아요 1296, 반대 505, 통과율 35.4%를 눌렀다.각 항목의 지표로 말하자면 보기에는 약간 규범에 맞는 것 같지만, 실제로도 확실히 그렇다.이 문제의 해법과 의도는 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.