본문 바로가기

프로그래머스31

[코딩테스트] 프로그래머스 - 단어 변환 (Lv.3) in Python 두 개의 단어 begin, target과 단어의 집합 words가 매개변수로 주어질 때, 최소 몇 단계의 과정을 거쳐 begin을 target으로 변환 가능한 지 알려주는 solution 함수 구현 programmers.co.kr/learn/courses/30/lessons/43163 풀이과정은 프로그래머스 수업 내용을 바탕으로 합니다. 풀이 - 너비 우선 탐색 (BFS)를 사용해서 풀면 효율적이다. - 너비 우선 탐색은 FIFO (선입선출) 로직을 사용하므로, 큐 자료구조가 적합하다. (참고 - 여행 경로 문제 (piaflu.tistory.com/62 ) # 비교할 두 단어가 변환 가능한 지 - 한 글자만 다름 - 확인 def possible(start, target): count = 0 for i i.. 2021. 3. 9.
[코딩테스트] 프로그래머스 - 기둥과 보 (2020 Kakao) in Python 벽면의 크기 n, 기둥과 보를 설치하거나 삭제하는 작업이 순서대로 담긴 2차원 배열 build_frame이 매개변수로 주어질 때, 모든 명령어를 수행한 후 구조물의 상태를 return 하도록 solution 함수를 완성! 더 상세한 설명↓ programmers.co.kr/learn/courses/30/lessons/60061 문제풀이는 프로그래머스의 강의를 바탕으로 작성하였습니다. 풀이 - 요구사항이 아주 자세하게 문제에 적혀 있다. - 요구사항을 하나 하나 따라하면 되는, "시뮬레이션 - Simulation" 문제로 정의될 수 있다 한다. - 시뮬레이션 문제는 보통 시간복잡도에 있어서 널널하게 주어진다고 한다. ~> 이번 문제 또한 O(N^3)으로도 (배열 활용), O(N^2)으로도 (Set와 Tupl.. 2021. 3. 9.
[코딩테스트] 프로그래머스 - 입국심사 (Lv.3) in Python 입국심사를 기다리는 사람 수 n, 각 심사관이 한 명을 심사하는 데 걸리는 시간이 담긴 배열 times가 주어질 때, 모든 사람이 심사를 받는 데 걸리는 최소 시간을 return하세요. programmers.co.kr/learn/courses/30/lessons/43238 풀이 - 입국심사에 드는 시간 중 최댓값 (최악의 경우)은 max(times) * n. - n은 최대 1억, times[i]는 최대 1분, times의 길이는 최대 10만 - 이렇게 변수의 크기가 크기 때문에, 최대한 알고리즘 수행 속도를 줄일 수 있게 이분탐색을 도입한다. - 기존 기본적인 이분탐색 문제와 다른 점은, 원하는 값이 mid와 같은 상황 - "Search 성공" -이, 꼭 우리가 원하는 답이라는 보장은 없다는 것이다. -.. 2021. 3. 9.
[코딩테스트] 프로그래머스 - 가사 검색(2020 Kakao) in Python 가사에 사용된 모든 단어들이 담긴 배열 words와 찾고자 하는 키워드가 담긴 배열 queries가 주어질 때, 각 키워드 별로 매치된 단어가 몇 개인지 순서대로 배열에 담아 반환하도록 solution 함수를 완성. ?는 한 글자를 나타내는 와일드카드이다. 예시: words = ["frodo", "front", "frost", "frozen", "frame", "kakao"], queries = ["fro??", "????o", "fr???", "fro???", "pro?"]일때, answer = [3, 2, 4, 1, 0] 잘못된 풀이 - 중첩의 중첩을 이용, 각 query마다 모든 단어의 모든 글자를 탐색하는 방법은, 역시나 효율성 테스트에서 실패했다. - words (100,000 이하), 각 가사.. 2021. 3. 9.