본문 바로가기
프로그래머스/2단계

(Python/LV2) 캐시

by windy7271 2022. 9. 22.
728x90
반응형

문제출처: https://school.programmers.co.kr/learn/courses/30/lessons/17680

 

프로그래머스

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

programmers.co.kr

풀이:

잘 안 돼서 다른 분의 풀이를 활용했다,,

def solution(cacheSize, cities):
    cache = []
    res = 0
    for i in cities:
        i = i.lower()
        if cacheSize:
            if not i in cache:
                if len(cache) == cacheSize:
                    cache.pop(0)
                cache.append(i)
                res += 5
            else:
                cache.pop(cache.index(i))
                cache.append(i)
                res += 1
        else :
            res += 5
    return res

 

 

내장함수 이용한 풀이

def solution(cacheSize, cities):
    import collections
    cache = collections.deque(maxlen=cacheSize)
    time = 0
    for i in cities:
        s = i.lower()
        if s in cache:
            cache.remove(s)
            cache.append(s)
            time += 1
        else:
            cache.append(s)
            time += 5
    return time

# 놀랍다

 

반응형

댓글