코딩테스트

    [프로그래머스/파이썬] 수박수박수박수박수박수?

    문제 설명 길이가 n이고, "수박수박수박수...."와 같은 패턴을 유지하는 문자열을 리턴하는 함수, solution을 완성하세요. 예를들어 n이 4이면 "수박수박"을 리턴하고 3이라면 "수박수"를 리턴하면 됩니다. 제한 조건 n은 길이 10,000이하인 자연수입니다. 입출력 예 n return 3 "수박수" 4 "수박수박" 내 풀이 "수박"은 두 글자 n을 2로 나눈 몫 만큼 "수박" 에 곱하기 홀수일 경우 나머지 만큼 "수" 이어붙이기 (항상 나머지는 0 또는 1) def solution(n): s = "수박" * (n//2) + "수" * (n%2) return s 다른 사람 풀이1 "수박"을 n 만큼 문자열로 만듦 3이면 "수박수박수박" 길이 n ex) n=3 으로 인덱싱하여 출력하면 "수박수" 문..

    [프로그래머스/파이썬] 가운데 글자 가져오기

    문제 실행 단어 s의 가운데 글자를 반환하는 함수, solution을 만들어 보세요. 단어의 길이가 짝수라면 가운데 두글자를 반환하면 됩니다. 제한사항 s는 길이가 1 이상, 100이하인 스트링입니다. 입출력 예 s return "abcde" "c" "qwer" "we" 내 풀이 문자열의 길이가 짝수이면 ex) "abcdef" 2로 나눈 몫에 1을 뺀 인덱스 부터 ex) index : 2 2로 나눈 몫에 1을 더한 인덱스 까지 ex) index: 4 인덱싱을 사용해서 출력 ex) "cd" 홀수인 경우에는 문자열의 가운데 인덱스를 구해서 출력 def solution(s): s_len = len(s) if len(s) % 2 == 0: return s[s_len//2-1 : s_len//2+1] else: ..

    [프로그래머스/파이썬] 음양 더하기

    문제 설명 어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 absolutes와 이 정수들의 부호를 차례대로 담은 불리언 배열 signs가 매개변수로 주어집니다. 실제 정수들의 합을 구하여 return 하도록 solution 함수를 완성해주세요. 제한사항 absolutes의 길이는 1 이상 1,000 이하입니다. absolutes의 모든 수는 각각 1 이상 1,000 이하입니다. signs의 길이는 absolutes의 길이와 같습니다. signs[i] 가 참이면 absolutes[i] 의 실제 정수가 양수임을, 그렇지 않으면 음수임을 의미합니다. 입출력 예 absolutes signs result [4,7,2] [true,false,true] 9 [1,2,3] [false,false..

    [프로그래머스/파이썬] 제일 작은 수 제거하기

    문제 설명 정수를 저장한 배열, arr 에서 가장 작은 수를 제거한 배열을 리턴하는 함수, solution을 완성해주세요. 단, 리턴하려는 배열이 빈 배열인 경우엔 배열에 -1을 채워 리턴하세요. 예를들어 arr이 [4,3,2,1]인 경우는 [4,3,2]를 리턴 하고, [10]면 [-1]을 리턴 합니다. 제한 조건 arr은 길이 1 이상인 배열입니다. 인덱스 i, j에 대해 i ≠ j이면 arr[i] ≠ arr[j] 입니다. 입출력 예 arr return [4,3,2,1] [4,3,2] [10] [-1] 내 풀이 배열 길이가 1보다 크다면 최솟값 min(arr) 를 arr에서 제거 def solution(arr): if len(arr) > 1 : arr.remove(min(arr)) return arr ..

    [프로그래머스/파이썬] 나누어 떨어지는 숫자 배열

    문제 설명 array의 각 element 중 divisor로 나누어 떨어지는 값을 오름차순으로 정렬한 배열을 반환하는 함수, solution을 작성해주세요. divisor로 나누어 떨어지는 element가 하나도 없다면 배열에 -1을 담아 반환하세요. 제한사항 arr은 자연수를 담은 배열입니다. 정수 i, j에 대해 i ≠ j 이면 arr[i] ≠ arr[j] 입니다. divisor는 자연수입니다. array는 길이 1 이상인 배열입니다. 입출력 예 arr divisor return [5,9,7,10] 5 [5,10] [2,36,1,3] 1 [1,2,3,36] [3,2,6] 10 [-1] 내 풀이 주어진 배열 요소가 divisor로 나누어지는 리스트 생성 리스트가 비어있다면 -1 넣어주기 sorted 를..

    [프로그래머스/파이썬] 핸드폰 번호 가리기

    문제 설명 프로그래머스 모바일은 개인정보 보호를 위해 고지서를 보낼 때 고객들의 전화번호의 일부를 가립니다. 전화번호가 문자열 phone_number로 주어졌을 때, 전화번호의 뒷 4자리를 제외한 나머지 숫자를 전부 *으로 가린 문자열을 리턴하는 함수, solution을 완성해주세요. 제한 조건 phone_number는 길이 4 이상, 20이하인 문자열입니다. 입출력 예 phone_number return "01033334444" "*******4444" "027778888" "*****8888" 내 풀이 전체 문자열에서 4를 뺸 수 만큼 * 생성 문자열 인덱싱으로 -4 번째 요소 부터 마지막 요소까지 이어붙임 def solution(phone_number): phone_len = len(phone_nu..

    [프로그래머스/파이썬] 서울에서 김서방 찾기

    문제 설명 String형 배열 seoul의 element중 "Kim"의 위치 x를 찾아, "김서방은 x에 있다"는 String을 반환하는 함수, solution을 완성하세요. seoul에 "Kim"은 오직 한 번만 나타나며 잘못된 값이 입력되는 경우는 없습니다. 제한 사항 seoul은 길이 1 이상, 1000 이하인 배열입니다. seoul의 원소는 길이 1 이상, 20 이하인 문자열입니다. "Kim"은 반드시 seoul 안에 포함되어 있습니다. 입출력 예 seoul return ["Jane","Kim"] "김서방은 1에 있다" 내 풀이 index함수를 통해 리스트 내에 "Kim" 의 인덱스 찾기 f-String 을 사용하여 return Kim을 찾을 때 큰 따옴표를 쓰기 위해 바깥은 작은 따옴표를 사용 ..