본문 바로가기

Algorithm/Programmers80

[프로그래머스] 더 맵게 /파이썬 /Python / heapq 💡solutions ) ✅ 처음에 heapq 자료구조 사용하지 않고 sort를 했다가 런타임 에러가 떴었다. 다른 분들은 처음부터 heapq를 사용하시길 바란다. ✅ 참고로 heapq는 heappush, heappop을 할 때 자동으로 정렬을 해주어 효율성이 높아진다고 한다. 🎫code ) import heapq def solution(scoville, K): items = [] for i in scoville: heapq.heappush(items, i) cnt = 0 while items[0] < K: try: heapq.heappush(items, heapq.heappop(items)+(heapq.heappop(items)*2)) except: return -1 cnt += 1 return cnt .. 2020. 8. 22.
[프로그래머스] 124 나라의 숫자 /파이썬 /Python 💡solutions ) ✅ 삼진법 -> 3으로 나눈 후 나머지를 num 리스트의 인덱스로 사용한다. ✅ 나머지가 0이면 num[0] = 1, 나머지 1이면 num[1] = 2, 나머지 2이면 num[2] = 4 🎫code ) def solution(n): num = ['1','2','4'] answer = "" while n > 0: n -= 1 answer = num[n % 3] + answer n //= 3 return answer 📌 description ) 문제출처 : programmers.co.kr/learn/courses/30/lessons/12899?language=python3 코딩테스트 연습 - 124 나라의 숫자 124 나라가 있습니다. 124 나라에서는 10진법이 아닌 다음과 같은 자.. 2020. 8. 21.
[프로그래머스] 시저 암호 /파이썬 /Python 💡solutions ) ✅ 대소문자 구분해준 후 ord 메소드로 아스키 코드 변환 -> 이때 마지막 Z를 벗어나는 경우는 26을 빼주어 다시 A로 돌아가 계산 -> chr 메소드로 다시 문자열 변환 ✅ 아래 아스키 코드표 참고 🎫code ) def solution(s, n): answer = '' s = list(s) for a in s: if a != ' ': num = ord(a) + n if 65 122: # 마지막 z 넘가는 경우 num = num - 26 res = chr(num) answer += res else: # 공백 문자 처리 answer += a return answer 📌 description ) 문제출처 : programmers.co.kr/learn/courses/30/lesson.. 2020. 8. 20.
[프로그래머스] 체육복 /파이썬 /Python 💡solutions ) ✅ 체육복 현황을 보여주는 students 리스트를 만들어 놓음, 체육복 있는 경우 1 없는 경우 0으로 표시 ✅ 체육복 여분을 가지고 있는 학생이 체육복을 잃어 버린 경우 -> lost, reserve 배열에서 모두 제거 (즉, 여분의 체육복 본인이 가짐) ✅ reserve 리스트를 반복문 돌리며 여분의 체육복을 나눠줌 ✅ 인덱스 범위를 넘어가는 지 확인하는데 중복 방지를 위해 continue 달아주기 - 인덱스 1인 경우에는 2번째 학생만 체크 - 인덱스 n인 경우(끝값) n-1번째 학생만 체크 ✅ 범위 벗어나지 않은 경우에는 i 기준으로 앞의 학생 먼저 체크한 후 -> 뒤의 학생 순으로 확인하기. 중복 방지를 위해 순서대로 체크하고 continue 조건 넣어주기 🎫code ).. 2020. 8. 19.
[프로그래머스] 가장 큰 수/ 파이썬/ Python/ 정렬/ sort 💡solutions ) ✅ 사용한 주요 함수는 lambda, map, sort , join이다. ✅ map 함수는 리스트의 요소를 지정된 함수로 처리해준다. 이 문제에서는 입력 받은 숫자 리스트를 각 요소별로 str 변환해주었다. sort에서 각 자릿수 별로 값을 비교하기 위해 문자열로 변환했다. ✅ sort 함수로 특정 key를 기준으로 정렬. 입력으로 주어지는 숫자가 1000 이하이기 때문에 key값으로 람다함수를 써줬다. x: x*3는 문자열에 3을 곱해주면 문자열을 3개씩 반복해서 나열한 것으로 나타냄. 값을 비교한 후 정렬한다. e.g.) 값이 5였으면 555로 값을 비교해서 정렬 ✅ join 함수는 리스트에 특정 구분자를 추가하여 문자열로 변환함. 여기서는 공백 없이 문자열로 합쳤다. ✅ 처음.. 2020. 8. 18.
[프로그래머스] 2016년 /파이썬 /Python 💡solutions ) ✅ 달마다 며칠인지 리스트에 넣어주기 ✅ 전체 일수를 합산하고 7로 나눈뒤 -1 (금요일이 1이니까) 🎫code ) def solution(a, b): month = [31,29,31,30,31,30,31,31,30,31,30,31] weekday = ["FRI","SAT","SUN","MON","TUE","WED","THU"] day = sum(month[:a-1]) + b if a > 1 else b answer = weekday[day % 7-1] return answer 📌 description ) 문제출처 : https://programmers.co.kr/learn/courses/30/lessons/12901?language=python3 코딩테스트 연습 - 2016년 2.. 2020. 8. 17.