상세 컨텐츠

본문 제목

[Programmers][Python] 캐시

공부

by 근성 2024. 1. 5. 14:57

본문

https://school.programmers.co.kr/learn/courses/30/lessons/17680

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

LRU 방식을 이용한 문제이다.


예전에는 평범하게 List(stack)로만 접근했다.

def solution(cacheSize, cities):
    answer = 0
    cache = []
    if cacheSize == 0:
        return 5*len(cities)
    else:
        for i in range(len(cities)):
            if cities[i].lower() not in cache:
                if len(cache) < cacheSize:
                    cache.append(cities[i].lower())
                elif len(cache) == cacheSize:
                    cache.pop(0)
                    cache.append(cities[i].lower())
                answer += 5
            else:
                cache.remove((cities[i].lower()))
                cache.append(cities[i].lower())
                answer += 1
    return answer

 

 

 

두번째 푸는 이 문제, 다른 방식인 deque(queue)로 접근해봤다.

from collections import deque
def solution(cacheSize, cities):
    answer = 0

    if cacheSize == 0:
        return 5 * len(cities)
    else:
        cache = []
        cache = deque(cache)
        for i in range(len(cities)):
            if cities[i].lower() not in cache:
                if len(cache) < cacheSize:
                    cache.append(cities[i].lower())
                elif len(cache) == cacheSize:
                    cache.popleft()
                    cache.append(cities[i].lower())
                answer += 5
            else:
                cache.remove(cities[i].lower())
                cache.append(cities[i].lower())
                answer += 1
    return answer

 

 

관련글 더보기

댓글 영역