코딩테스트 공부/프로그래머스 문제 7

프로그래머스 DP_정수 삼각형

프로그래머스 DP(다이나믹 프로그래밍) 정수 삼각형 문제 풀이입니다. 문제 설명 위와 같은 삼각형의 꼭대기에서 바닥까지 이어지는 경로 중, 거쳐간 숫자의 합이 가장 큰 경우를 찾아보려고 합니다. 아래 칸으로 이동할 때는 대각선 방향으로 한 칸 오른쪽 또는 왼쪽으로만 이동 가능합니다. 예를 들어 3에서는 그 아래칸의 8 또는 1로만 이동이 가능합니다. 삼각형의 정보가 담긴 배열 triangle이 매개변수로 주어질 때, 거쳐간 숫자의 최댓값을 return 하도록 solution 함수를 완성하세요. 제한사항 삼각형의 높이는 1 이상 500 이하입니다. 삼각형을 이루고 있는 숫자는 0 이상 9,999 이하의 정수입니다. 입출력 예 triangle : [[7], [3, 8], [8, 1, 0], [2, 7, 4,..

프로그래머스_해시_전화번호 목록

난이도가 낮은편인 문제 해시를 이용하지 않고 풀었다. 다만, 효율성 테스트에서 처음에 떨어졌음. 문제 문제 설명 전화번호부에 적힌 전화번호 중, 한 번호가 다른 번호의 접두어인 경우가 있는지 확인하려 합니다. 전화번호가 다음과 같을 경우, 구조대 전화번호는 영석이의 전화번호의 접두사입니다. 구조대 : 119 박준영 : 97 674 223 지영석 : 11 9552 4421 전화번호부에 적힌 전화번호를 담은 배열 phone_book 이 solution 함수의 매개변수로 주어질 때, 어떤 번호가 다른 번호의 접두어인 경우가 있으면 false를 그렇지 않으면 true를 return 하도록 solution 함수를 작성해주세요. 제한 사항 phone_book의 길이는 1 이상 1,000,000 이하입니다. 각 전화..

프로그래머스 해시_완주하지 못한 선수

프로그래머스 문제중 level 1에 해당하는 쉬운 문제지만 '해시'라는 key-value쌍을 가지는 자료구조를 잘 이해할 필요가 있다. 문제 수많은 마라톤 선수들이 마라톤에 참여하였습니다. 단 한 명의 선수를 제외하고는 모든 선수가 마라톤을 완주하였습니다. 마라톤에 참여한 선수들의 이름이 담긴 배열 participant와 완주한 선수들의 이름이 담긴 배열 completion이 주어질 때, 완주하지 못한 선수의 이름을 return 하도록 solution 함수를 작성해주세요. 나의 풀이 def solution(participant, completion): participant.sort() completion.sort() for c in completion: participant.remove(c) return..

프로그래머스_스택_탑

적당한 시간내에 적당히 잘 푼것같은 문제이다. 근데 효율성 측면은 잘 모르겠다. 문제 수평 직선에 탑 N대를 세웠습니다. 모든 탑의 꼭대기에는 신호를 송/수신하는 장치를 설치했습니다. 발사한 신호는 신호를 보낸 탑보다 높은 탑에서만 수신합니다. 또한, 한 번 수신된 신호는 다른 탑으로 송신되지 않습니다. 예를 들어 높이가 6, 9, 5, 7, 4인 다섯 탑이 왼쪽으로 동시에 레이저 신호를 발사합니다. 그러면, 탑은 다음과 같이 신호를 주고받습니다. 높이가 4인 다섯 번째 탑에서 발사한 신호는 높이가 7인 네 번째 탑이 수신하고, 높이가 7인 네 번째 탑의 신호는 높이가 9인 두 번째 탑이, 높이가 5인 세 번째 탑의 신호도 높이가 9인 두 번째 탑이 수신합니다. 높이가 9인 두 번째 탑과 높이가 6인 첫..

프로그래머스_완전탐색_모의고사

문제를 풀면서도 이건 좀 아니다.. 하면서 풀었던 문제 간단해보이는 문제가 60줄이나작 된다. 확실히 코드 자체의 시간 효율성도 떨어지고 작업 효율성.. 그러니까 이렇게 풀면 풀이시간이 엄청 오래걸릴것같다. 오류가 나도 찾기가 힘들듯.. 좀 더 깔끔하게 풀 수 있는 방법을 고민해보면 좋을 것 같다. 문제설명 수포자는 수학을 포기한 사람의 준말입니다. 수포자 삼인방은 모의고사에 수학 문제를 전부 찍으려 합니다. 수포자는 1번 문제부터 마지막 문제까지 다음과 같이 찍습니다. 1번 수포자가 찍는 방식: 1, 2, 3, 4, 5, 1, 2, 3, 4, 5, ... 2번 수포자가 찍는 방식: 2, 1, 2, 3, 2, 4, 2, 5, 2, 1, 2, 3, 2, 4, 2, 5, ... 3번 수포자가 찍는 방식: 3..

2019 카카오 겨울 인턴쉽_크레인 인형뽑기 게임

작년에 경험삼아 쳐본 2019 카카오 인턴쉽 알고리즘 코딩테스트 문제를 프로그래머스에서 발견해서 다시 한번 풀어본다. 그 당시 이문제만 풀고 나머지 문제는 시간/코딩 능력 상 못 풀었었는데 다시 푸니까 이상한데에서 헤매서 또 시간이 오래 걸렸다.. 사소한 실수를 반복하지 않도록 연습할 필요가 있을 것 같다. 문제 출처: https://programmers.co.kr/learn/courses/30/lessons/64061?language=python3 게임 화면은 1 x 1 크기의 칸들로 이루어진 N x N 크기의 정사각 격자이며 위쪽에는 크레인이 있고 오른쪽에는 바구니가 있습니다. (위 그림은 5 x 5 크기의 예시입니다). 각 격자 칸에는 다양한 인형이 들어 있으며 인형이 없는 칸은 빈칸입니다. 모든 ..

프로그래머스 해시_위장 (Counter, reduce)

위장 스파이들은 매일 다른 옷을 조합하여 입어 자신을 위장합니다. 예를 들어 스파이가 가진 옷이 아래와 같고 오늘 스파이가 동그란 안경, 긴 코트, 파란색 티셔츠를 입었다면 다음날은 청바지를 추가로 입거나 동그란 안경 대신 검정 선글라스를 착용하거나 해야 합니다. 스파이가 가진 의상들이 담긴 2차원 배열 clothes가 주어질 때 서로 다른 옷의 조합의 수를 return 하도록 solution 함수를 작성해주세요. 제한사항 clothes의 각 행은 [의상의 이름, 의상의 종류]로 이루어져 있습니다. 스파이가 가진 의상의 수는 1개 이상 30개 이하입니다. 같은 이름을 가진 의상은 존재하지 않습니다. clothes의 모든 원소는 문자열로 이루어져 있습니다. 모든 문자열의 길이는 1 이상 20 이하인 자연수..