알고리즘/프로그래머스 PS58 [프로그래머스][Level 1][Python] 자연수 뒤집어 배열로 만들기 밑의 링크는 프로그래머스에서의 문제 링크입니다. 코딩테스트 연습 - 자연수 뒤집어 배열로 만들기 자연수 n을 뒤집어 각 자리 숫자를 원소로 가지는 배열 형태로 리턴해주세요. 예를들어 n이 12345이면 [5,4,3,2,1]을 리턴합니다. 제한 조건 n은 10,000,000,000이하인 자연수입니다. 입출력 예 n return 12345 programmers.co.kr 파이썬 코드와 결과입니다. # 자연수 n이 매개변수로 주어집니다. def solution(n): # n을 문자열로 바꾸고 각 문자들을 원소로 가지는 리스트로 만들어줍니다. # 각 원소를 정수형으로 변환하고 리스트로 만들어준 뒤 뒤집어줍니다. # 최종적으로 다시 리스트로 만들어줍니다. answer = list(reversed(list(map(.. 2021. 7. 10. [프로그래머스][Level 1][Python] 자릿수 더하기 밑의 링크는 프로그래머스에서의 문제 링크입니다. 코딩테스트 연습 - 자릿수 더하기 자연수 N이 주어지면, N의 각 자릿수의 합을 구해서 return 하는 solution 함수를 만들어 주세요. 예를들어 N = 123이면 1 + 2 + 3 = 6을 return 하면 됩니다. 제한사항 N의 범위 : 100,000,000 이하의 자연수 입출 programmers.co.kr 파이썬 코드와 결과입니다. # 자연수 n이 매개변수로 주어집니다. def solution(n): # 자연수 n의 각 자릿수의 합을 저장하는 변수를 선언합니다. answer = sum(map(int, list(str(n)))) # 자연수 n의 각 자릿수의 합을 반환합니다. return answer ※ 궁금한 부분, 이상한 점 및 오타는 댓글에.. 2021. 7. 10. [프로그래머스][Level 1][Python] 콜라츠 추측 밑의 링크는 프로그래머스에서의 문제 링크입니다. 코딩테스트 연습 - 콜라츠 추측 1937년 Collatz란 사람에 의해 제기된 이 추측은, 주어진 수가 1이 될때까지 다음 작업을 반복하면, 모든 수를 1로 만들 수 있다는 추측입니다. 작업은 다음과 같습니다. 1-1. 입력된 수가 짝수라면 2 programmers.co.kr 파이썬 코드와 결과입니다. # 1 이상 8,000,000 미만인 정수 num이 매개변수로 주어집니다. def solution(num): # 정답을 저장할 변수를 선언합니다. # 0으로 초기화합니다. answer = 0 # 정답을 찾을 때까지 계속 반복해봅니다. while True: # num이 1이 된다면 if num == 1: # 반복문을 탈출합니다. break # answer가 5.. 2021. 7. 10. [프로그래머스][Level 1][Python] 숫자 문자열과 영단어 밑의 링크는 프로그래머스에서의 문제 링크입니다. 코딩테스트 연습 - 숫자 문자열과 영단어 네오와 프로도가 숫자놀이를 하고 있습니다. 네오가 프로도에게 숫자를 건넬 때 일부 자릿수를 영단어로 바꾼 카드를 건네주면 프로도는 원래 숫자를 찾는 게임입니다. 다음은 숫자의 일부 자 programmers.co.kr 파이썬 코드와 결과입니다. # 숫자의 일부 자릿수가 영단어로 바뀌어졌거나, 혹은 바뀌지 않고 그대로인 문자열 s가 매개변수로 주어집니다. def solution(s): # 문자열 s가 의미하는 원래 숫자를 저장할 변수를 선언합니다. answer = '' # 각 영단어가 의미하는 숫자를 연결시켜놓은 딕셔너리 변수를 선언합니다. eng_num = { 'zero': '0', 'one': '1', 'two': .. 2021. 7. 9. [프로그래머스][Level 1][Python] 이상한 문자 만들기 밑의 링크는 프로그래머스에서의 문제 링크입니다. 코딩테스트 연습 - 이상한 문자 만들기 문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 programmers.co.kr 파이썬 코드와 결과입니다. # 한 개 이상의 단어로 구성되어 있는 문자열 s가 매개변수로 주어집니다. def solution(s): # 변환된 단어들이 저장될 리스트 변수를 선언합니다. answer = [] # 문자열 s를 공백으로 구분한 단어들을 저장한 리스트 변수를 선언합니다. words = s.split(' ') # words의 한 단어씩 반복해봅니다. for word in words: # 현재 .. 2021. 7. 9. [프로그래머스][Level 1][Python] 문자열 내 마음대로 정렬하기 밑의 링크는 프로그래머스에서의 문제 링크입니다. 코딩테스트 연습 - 문자열 내 마음대로 정렬하기 문자열로 구성된 리스트 strings와, 정수 n이 주어졌을 때, 각 문자열의 인덱스 n번째 글자를 기준으로 오름차순 정렬하려 합니다. 예를 들어 strings가 ["sun", "bed", "car"]이고 n이 1이면 각 단어의 인덱 programmers.co.kr 파이썬 코드와 결과입니다. # 문자열로 구성된 리스트 strings, 정렬 기준이 될 정수 n이 매개변수로 주어집니다. def solution(strings, n): # strings에 있는 문자열들을 각 문자열의 인덱스 n번째 글자를 기준으로 오름차순 정렬합니다. # 인덱스 n번째의 문자가 같은 문자열이 여럿일 경우 사전순으로 정렬합니다. # 결.. 2021. 7. 9. [프로그래머스][Level 1][Python] 하샤드 수 밑의 링크는 프로그래머스에서의 문제 링크입니다. 코딩테스트 연습 - 하샤드 수 양의 정수 x가 하샤드 수이려면 x의 자릿수의 합으로 x가 나누어져야 합니다. 예를 들어 18의 자릿수 합은 1+8=9이고, 18은 9로 나누어 떨어지므로 18은 하샤드 수입니다. 자연수 x를 입력받아 x가 하 programmers.co.kr 파이썬 코드와 결과입니다. # 양의 정수 x가 매개변수로 주어집니다. def solution(x): # 양의 정수 x가 하샤드 수인지 아닌지를 저장하는 변수를 선언합니다. # 처음에는 x가 하샤드 수가 맞다는 뜻인 True로 초기화합니다. answer = True # x의 자릿수의 합을 저장하는 변수를 선언합니다. position_sum = sum(map(int, list(str(x))).. 2021. 7. 8. [프로그래머스][Level 1][Python] 문자열 내림차순으로 배치하기 밑의 링크는 프로그래머스에서의 문제 링크입니다. 코딩테스트 연습 - 문자열 내림차순으로 배치하기 문자열 s에 나타나는 문자를 큰것부터 작은 순으로 정렬해 새로운 문자열을 리턴하는 함수, solution을 완성해주세요. s는 영문 대소문자로만 구성되어 있으며, 대문자는 소문자보다 작은 것으로 programmers.co.kr 파이썬 코드와 결과입니다. # 문자열 s가 매개변수로 주어집니다. def solution(s): # 문자열 s를 한 글자씩 저장되어 있는 리스트 변수로 만들어줍니다. s = list(s) # s에 있는 각 문자들을 내림차순으로 정렬합니다. s.sort(reverse=True) # 리스트 변수 s를 다시 문자열로 만들어줍니다. answer = ''.join(s) # 내림차순된 문자열을 반.. 2021. 7. 8. [프로그래머스][Level 1][Python] 문자열 다루기 기본 밑의 링크는 프로그래머스에서의 문제 링크입니다. 코딩테스트 연습 - 문자열 다루기 기본 문자열 s의 길이가 4 혹은 6이고, 숫자로만 구성돼있는지 확인해주는 함수, solution을 완성하세요. 예를 들어 s가 "a234"이면 False를 리턴하고 "1234"라면 True를 리턴하면 됩니다. 제한 사항 s는 길이 1 programmers.co.kr 파이썬 코드와 결과입니다. # 문자열 s가 매개변수로 주어집니다. def solution(s): # 조건에 맞는 문자열인지 아닌지를 저장할 변수를 선언합니다. # 처음에는 조건에 맞는 문자열이라는 뜻인 True로 초기화합니다. answer = True # 문자열 s의 길이를 저장하는 변수를 선언합니다. s_len = len(s) # 문자열 s의 길이가 4 혹은.. 2021. 7. 8. [프로그래머스][Level 1][Python] [1차] 비밀지도 밑의 링크는 프로그래머스에서의 문제 링크입니다. 코딩테스트 연습 - [1차] 비밀지도 비밀지도 네오는 평소 프로도가 비상금을 숨겨놓는 장소를 알려줄 비밀지도를 손에 넣었다. 그런데 이 비밀지도는 숫자로 암호화되어 있어 위치를 확인하기 위해서는 암호를 해독해야 한다. 다 programmers.co.kr 파이썬 코드와 결과입니다. # 지도의 한 변 크기 n, 지도 2개의 정보를 저장한 리스트 arr1, arr2가 매개변수로 주어집니다. def solution(n, arr1, arr2): # 원래의 비밀지도를 해독한 정보를 저장할 리스트 변수를 선언합니다. answer = [None] * n # 지도의 한 변의 크기 n만큼 반복합니다. for idx in range(n): # 원래 비밀지도의 현재의 한 줄을 .. 2021. 7. 7. 이전 1 2 3 4 5 6 다음