[프로그래머스 | 파이썬] 캐시(2018 KAKAO BLIND RECRUITMENT/ level 2)

2023. 1. 1. 16:31·Problem Solving/프로그래머스
반응형
문제

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

 

프로그래머스

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

programmers.co.kr

 

 

 

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

 

 

 

코드 설명

1️⃣ 캐시 크기가 0인 경우 cities배열의 크기를 리턴하도록 한다.(예외 처리)

2️⃣ 캐시 크기가 0이 아닌 경우 아래 3️⃣ ~ 5️⃣를 수행한다.

3️⃣ cities의 모든 원소를 소문자로 변경한다.

4️⃣ 만약 stack 안에 cities의 원소가 없다면(=해당 원소에 접근한 적이 없다는 뜻) cache miss이므로 실행시간을 5초 추가한다. 이때 스택이 가득 차 있다면 가장 처음 접근한 원소를 삭제해 공간을 비워준다. 이후 스택에 cities의 원소를 추가해 해당 원소에 접근했음을 표시한다.

5️⃣ 만약 stack 안에 cities의 원소가 존재한다면, cache hit이므로 실행시간을 1초 추가한다. 또한 스택에서 해당 원소값을 삭제한 뒤 스택의 가장 맨 뒤에 추가해 해당 원소를 가장 마지막에 접근했음을 표시한다.

 

 

더보기

➕ 실패한 코드

 

def solution(cacheSize, cities):
    if cacheSize == 0:
        return len(cities) * 5
    else:
        answer = 0
        cities = [i.lower() for i in cities]
        print(cities)
        visit_idx = [0] * cacheSize
        ls = [cities[i] for i in range(cacheSize)]
        for i in range(cacheSize, len(cities)):
            if cities[i] not in ls:
                answer += 5
                ls[visit_idx.index(min(visit_idx))] = cities[i]
            elif cities[i] in ls:
                answer += 1
            print(ls)
            visit_idx[ls.index(cities[i])] += 1
            print(visit_idx)
        return answer + 5 * cacheSize

 

 [출력결과]

['jeju', 'pangyo', 'seoul', 'newyork', 'la', 'jeju', 'pangyo', 'seoul', 'newyork', 'la']
['newyork', 'pangyo', 'seoul']
[1, 0, 0]
['newyork', 'la', 'seoul']
[1, 1, 0]
['newyork', 'la', 'jeju']
[1, 1, 1]
['pangyo', 'la', 'jeju']
[2, 1, 1]
['pangyo', 'seoul', 'jeju']
[2, 2, 1]
['pangyo', 'seoul', 'newyork']
[2, 2, 2]
['la', 'seoul', 'newyork']
[3, 2, 2]

 

제출 전 예제는 모두 맞는데 제출해보면 4개 정도 틀린 정답이라고 나온다. 뭐가 잘못된 건지 모르겠다ㅠㅠ

틀린 풀이지만 오랜 시간동안 고민하고 작성한 코드라 그냥 버리기 아까워서 기록.

접근목록 리스트, 캐시 리스트 두개의 리스트를 만들어서, 접근 목록 리스트의 가장 접근횟수가 적은 인덱스를 구한 뒤 캐시리스트의 해당 인덱스(접근횟수가 가장 적은 인덱스)에 새로운 원소를 등록하는 식으로 구현. 

 

반응형
저작자표시 비영리 변경금지 (새창열림)

'Problem Solving > 프로그래머스' 카테고리의 다른 글

[프로그래머스 | 파이썬 / 자바스크립트] 가위 바위 보(코딩테스트 입문/ level 0)  (2) 2023.02.19
[프로그래머스 | 파이썬 / 자바스크립트] 주사위의 개수(코딩테스트 입문/ level 0)  (0) 2023.02.19
[프로그래머스 | 파이썬 / 자바스크립트] 짝수 홀수 개수(코딩테스트 입문/ level 0)  (0) 2023.02.19
[프로그래머스 | 파이썬] H-Index(정렬/ level 2)  (0) 2022.12.30
[프로그래머스 | 파이썬] 비밀지도 (2018 KAKAO BLIND RECRUITMENT/ level 1)  (0) 2022.12.28
[프로그래머스 | 파이썬] 카펫 (완전탐색 / level 2)  (0) 2022.12.28
'Problem Solving/프로그래머스' 카테고리의 다른 글
  • [프로그래머스 | 파이썬 / 자바스크립트] 주사위의 개수(코딩테스트 입문/ level 0)
  • [프로그래머스 | 파이썬 / 자바스크립트] 짝수 홀수 개수(코딩테스트 입문/ level 0)
  • [프로그래머스 | 파이썬] H-Index(정렬/ level 2)
  • [프로그래머스 | 파이썬] 비밀지도 (2018 KAKAO BLIND RECRUITMENT/ level 1)
청량리 물냉면
청량리 물냉면
프로그래밍 공부를 하고 있습니다. 공부 내용 정리 겸 정보 공유를 목적으로 합니다.
    반응형
  • 청량리 물냉면
    노력중인 블로그
    청량리 물냉면
  • 전체
    오늘
    어제
    • 분류 전체보기 N
      • 프로그래밍 N
        • Programming N
        • C | C++
        • Java
        • Python
      • 웹 프로그래밍
        • HTML | CSS
        • JavaScript | TypeScript
        • React
        • Vue.js
        • Next.js
        • Spring & Spring Boot
        • JSP & Servlet
        • DB
      • 웹 프로젝트
        • 웹 프로젝트
        • 🥨스낵몰
        • 👨‍👨‍👧‍👧소셜 가계부
        • 🌜꿈 일기장
        • 🔮포트폴리오 사이트
        • 🏃‍♂️팀 프로젝트: 일정관리 프로그램
        • 📈팀 프로젝트: AI기반 주식 분석 플랫폼
        • 😺Just Meow It: 고양이의 조언
      • 앱 프로그래밍
        • Flutter
        • Kotlin
      • Problem Solving
        • 백준
        • 프로그래머스
        • SWEA
      • Computer Science N
        • 알고리즘 N
        • 컴퓨터 네트워크
        • 이산수학
      • Developer
        • 후기
        • 자료정리
        • 취업 | 취준
        • 웹개발 교육 프로그램
        • TIL
  • 블로그 메뉴

    • 홈
    • Github
  • 공지사항

    • 프로그래밍 공부 중😊
  • 인기 글

  • 태그

    리액트
    강의내용정리
    AWS
    공식문서
    백준
    Til
    bfs
    자바
    파이썬
    컴퓨터네트워크
    타입스크립트
    구현
    웹사이트
    프로젝트
    SWEA
    Next.js
    포트폴리오
    뉴렉처
    React
    프로그래머스
    spring boot
    알고리즘
    d3
    Jiraynor Programming
    ZeroCho
    클론 프로젝트
    mysql
    플러터
    자바스크립트
    블로그 제작
  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
청량리 물냉면
[프로그래머스 | 파이썬] 캐시(2018 KAKAO BLIND RECRUITMENT/ level 2)
상단으로

티스토리툴바