GitHub ID : soohyun-dev
윤수현의 개발 공간
GitHub ID : soohyun-dev
전체 방문자
오늘
어제
  • 분류 전체보기 (918)
    • 성장기록 (49)
      • 성장기록 (3)
      • 우아한테크코스 (16)
      • 프로젝트 (15)
      • TIL (14)
      • 테오의 스프린트 (1)
    • 프로그래밍언어 (88)
      • C언어 (14)
      • HTML\CSS (12)
      • JavaScript (7)
      • React (23)
      • Python (11)
      • JAVA (14)
      • TypeScript (6)
    • 알고리즘 공부 (736)
      • 코드업 - 파이썬 (108)
      • 백준 - 파이썬 (468)
      • 백준 - 자바스크립트 (125)
      • 프로그래머스 - 파이썬 (1)
      • 프로그래머스 - 자바스크립트 (34)
    • 책 리뷰 (9)
      • 프로그래밍 (3)
      • 독서 (6)
    • 전자기기 (1)
    • 일상, 일기 (18)
    • 기술 세미나 (2)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 코드업
  • PYTHON
  • 프로그래머스자바스크립트
  • 코드업파이썬
  • 프로그래밍언어
  • 자바스크립트
  • 코딩테스트
  • 백준
  • 프론트엔드
  • 프로그래머스
  • 영어
  • 백준파이썬
  • 영어독해
  • 코딩
  • 독해
  • 코테
  • 백준풀이
  • 프로그래머스풀이
  • javascript
  • 파이썬

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
GitHub ID : soohyun-dev

윤수현의 개발 공간

프로그래머스 / Level 2 , 2018 KAKAO BLIND RECRUITMENT , [1차] 캐시 자바스크립트 , JS
알고리즘 공부/프로그래머스 - 자바스크립트

프로그래머스 / Level 2 , 2018 KAKAO BLIND RECRUITMENT , [1차] 캐시 자바스크립트 , JS

2022. 9. 22. 17:46

프로그래머스 / Level 2 , 2018 KAKAO BLIND RECRUITMENT , [1차] 캐시 자바스크립트 , JS

 

 

문제 출처

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

 

프로그래머스

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

programmers.co.kr

 

 

 

풀이

그냥 무작정 집어 넣으면 안되고 문제에서 요구하는 LRU (Least Recently Used) 알고리즘을 적용해야한다.

 

1. 캐시 안에 넣을려는 값이 담겨져 있다면 cache hit 인 경우로 실행시간은 1초만 증가한다. 

중요한 점은 캐시에서 cache hit 인 값을 삭제하고 새로 맨 뒤로 추가해주는 것이다.

 

(그냥 무작정 맨앞에 있는 값을 삭제해버리면 안됨! 주의)

 

 

ex ) 

 

caheSize 가 5인 상황에서 캐시에 [1, 2, 3 ,4, 5] 가 담겨져 있다 가정하자

 

다음 값이 2가 들어올경우 cache hit 가 발생한다.

 

이 경우 캐시 값은 [1, 2, 3, 4, 5]  => [1, 3, 4, 5, 2] 가 되게 된다.

 

[2, 3, 4, 5, 2] 가 되는 게 아니니 주의하자.

 

 

 

2. 이외의 경우들은 cache miss 인 경우이므로 그냥 차례대로 넣어주고 실행시간은 5초 증가한다.

 

이 경우에는 caheSize 보다 커지는지 확인해주고 커진다면 가장 먼저 넣었던 값을 삭제해준다.

 

 

 

 

 

 

 

 

 

정답

 

function solution(cacheSize, cities) {
  var answer = 0;
  let arr = [];
  for (let i of cities) {
    let tmp = i.toLowerCase();
    if (arr.includes(tmp)) {
      arr = arr.filter((e) => e !== tmp);
      answer += 1;
      arr.push(tmp);
    } else {
      answer += 5;
      arr.push(tmp);
      if (arr.length > cacheSize) {
        arr = [...arr.splice(1, cacheSize)];
      }
    }
  }
  return answer;
}

 

 

반응형

'알고리즘 공부 > 프로그래머스 - 자바스크립트' 카테고리의 다른 글

프로그래머스 / Level 2 , 연습문제 , 멀리 뛰기 자바스크립트 , JS  (0) 2022.09.23
프로그래머스 / Level 2 , 깊이/너비 우선 탐색(DFS/BFS) , 게임 맵 최단거리 자바스크립트 , JS  (0) 2022.09.22
프로그래머스 / Level 2 , 월간 코드 챌린지 시즌2 , 괄호 회전하기 자바스크립트 , JS  (1) 2022.09.22
프로그래머스 / Level 2 , 정렬 , H-Index 자바스크립트 , JS  (0) 2022.09.22
프로그래머스 / Level2 , 연습문제 , 행렬의 곱셈 자바스크립트 , JS  (0) 2022.09.21
    '알고리즘 공부/프로그래머스 - 자바스크립트' 카테고리의 다른 글
    • 프로그래머스 / Level 2 , 연습문제 , 멀리 뛰기 자바스크립트 , JS
    • 프로그래머스 / Level 2 , 깊이/너비 우선 탐색(DFS/BFS) , 게임 맵 최단거리 자바스크립트 , JS
    • 프로그래머스 / Level 2 , 월간 코드 챌린지 시즌2 , 괄호 회전하기 자바스크립트 , JS
    • 프로그래머스 / Level 2 , 정렬 , H-Index 자바스크립트 , JS
    GitHub ID : soohyun-dev
    GitHub ID : soohyun-dev
    환영합니다!😊 이곳은 저의 개발에 관한 내용들을 정리하는 공간입니다. 알고리즘 풀이에도 관심이 많아요. 좋은 하루 되세요~! github : soohyun_dev

    티스토리툴바