[ Programming/코딩테스트 ][프로그래머스] 내적 - zip, mapIndexed2023-12-07 09:47:49▷ 해결 날짜 : 2023.12.07 ▷ 소요 시간 : 5분 ▷ 사용 언어 : 코틀린 🔎문제 : 길이가 같은 두 1차원 정수 배열 a, b가 매개변수로 주어집니다. a와 b의 내적을 return 하도록 solution 함수를 완성해주세요. 이때, a와 b의 내적은 a[0]*b[0] + a[1]*b[1] + ... + a[n-1]*b[n-1] 입니다. (n은 a, b의 길이) 📑제한사항 : a, b의 길이는 1 이상 1,000 이하입니다. a, b의 모든 수는 -1,000 이상 1,000 이하입니다. 📑입출력 예 a b return [1,2,3,4] [-3,-1,0,2] 3 [-1,0,1] [1,0,-1] -2 📑입출력 예시 #1 a와 b의 내적은 1*(-3) + 2*(-1) + 3*0 + 4*2 = 3 ..
[ Programming/코딩테스트 ][프로그래머스] 수박수박수박수박수박수?2023-12-07 09:27:38▷ 해결 날짜 : 2023.12.07 ▷ 소요 시간 : 10분 ▷ 사용 언어 : 코틀린 🔎문제 : 길이가 n이고, "수박수박수박수...."와 같은 패턴을 유지하는 문자열을 리턴하는 함수, solution을 완성하세요. 예를들어 n이 4이면 "수박수박"을 리턴하고 3이라면 "수박수"를 리턴하면 됩니다. 📑제한사항 : n은 길이 10,000이하인 자연수입니다. 📑입출력 예 n answer 3 "수박수" 4 "수박수박" ⌨본인 코드 class Solution { fun solution(n: Int): String { var answer = "" for(i in 1..n) { if(i%2 == 0) { answer += "박" } else answer += "수" } return answer } } 실수한점 a..
[ Programming/코딩테스트 ][프로그래머스] 가운데 글자 가져오기(substring, slice)2023-12-06 10:45:37▷ 해결 날짜 : 2023.12.06 ▷ 소요 시간 : 20분 ▷ 사용 언어 : 코틀린 🔎문제 : 단어 s의 가운데 글자를 반환하는 함수, solution을 만들어 보세요. 단어의 길이가 짝수라면 가운데 두글자를 반환하면 됩니다. 📑제한사항 : s는 길이가 1 이상, 100이하인 스트링입니다. 📑입출력 예 s return "abcde" "c" "qwer" "we" ⌨본인 코드 class Solution { fun solution(s: String): String { var answer = "" answer = s.substring((s.length-1)/2, s.length/2+1) return answer } } 실수한점 substring을 잘못 이해, 시작점은 이해했지만, 끝점에 적힌 인덱스값까지가 ..
[ Programming/코딩테스트 ][프로그래머스] 제일 작은 수 제거하기2023-12-05 10:29:02▷ 해결 날짜 : 2023.12.05 ▷ 소요 시간 : 20분 ▷ 사용 언어 : 코틀린 🔎문제 : 정수를 저장한 배열, 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] ⌨본인 코드 class Solution { fun solution(arr: IntArray): IntArray..
[ Programming/코딩테스트 ][프로그래머스] 없는 숫자 더하기2023-12-05 09:10:15▷ 해결 날짜 : 2023.12.05 ▷ 소요 시간 : 5분 ▷ 사용 언어 : 코틀린 🔎문제 : 0부터 9까지의 숫자 중 일부가 들어있는 정수 배열 numbers가 매개변수로 주어집니다. numbers에서 찾을 수 없는 0부터 9까지의 숫자를 모두 찾아 더한 수를 return 하도록 solution 함수를 완성해주세요. 📑제한사항 : 1 ≤ numbers의 길이 ≤ 9 0 ≤ numbers의 모든 원소 ≤ 9 numbers의 모든 원소는 서로 다릅니다. 📑입출력 예 numbers result [1,2,3,4,6,7,8,0] 14 [5,8,4,0,6,7,9] 6 📑입출력 예시 #1 5, 9가 numbers에 없으므로, 5 + 9 = 14를 return 해야 합니다. 📑입출력 예시 #2 1, 2, 3이 nu..
[ Programming/코딩테스트 ][프로그래머스] 핸드폰 번호 가리기2023-12-04 11:11:25▷ 해결 날짜 : 2023.12.04 ▷ 소요 시간 : 20분 ▷ 사용 언어 : 코틀린 🔎문제 : 프로그래머스 모바일은 개인정보 보호를 위해 고지서를 보낼 때 고객들의 전화번호의 일부를 가립니다. 전화번호가 문자열 phone_number로 주어졌을 때, 전화번호의 뒷 4자리를 제외한 나머지 숫자를 전부 *으로 가린 문자열을 리턴하는 함수, solution을 완성해주세요. 📑제한사항 : phone_number는 길이 4 이상, 20이하인 문자열입니다. 📑입출력 예 phone_number return "01033334444" "*******4444" "027778888" "*****8888" ⌨본인 코드 class Solution { fun solution(phone_number: String): Strin..
[ Programming/코딩테스트 ][프로그래머스] 음양 더하기2023-12-04 09:19:49▷ 해결 날짜 : 2023.12.04 ▷ 소요 시간 : 5분 ▷ 사용 언어 : 코틀린 🔎문제 : 어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 absolutes와 이 정수들의 부호를 차례대로 담은 불리언 배열 signs가 매개변수로 주어집니다. 실제 정수들의 합을 구하여 return 하도록 solution 함수를 완성해주세요. 📑제한사항 : absolutes의 길이는 1 이상 1,000 이하입니다. - absolutes의 모든 수는 각각 1 이상 1,000 이하입니다. signs의 길이는 absolutes의 길이와 같습니다. - signs[i] 가 참이면 absolutes[i] 의 실제 정수가 양수임을, 그렇지 않으면 음수임을 의미합니다. 📑입출력 예 absolutes signs..
[ Programming/코딩테스트 ][프로그래머스] 나누어 떨어지는 숫자 배열2023-12-01 11:04:42▷ 해결 날짜 : 2023.12.01 ▷ 소요 시간 : 15분 ▷ 사용 언어 : 코틀린 🔎문제 : array의 각 element 중 divisor로 나누어 떨어지는 값을 오름차순으로 정렬한 배열을 반환하는 함수, solution을 작성해주세요. divisor로 나누어 떨어지는 element가 하나도 없다면 배열에 -1을 담아 반환하세요. 📑제한사항 : arr은 자연수를 담은 배열입니다. 정수 i, j에 대해 i ≠ j 이면 arr[i] ≠ arr[j] 입니다. divisor는 자연수입니다. array는 길이 1 이상인 배열입니다. 📑입출력 예 arr divisor answer [5, 9, 7, 10] 5 [5, 10] [2, 36, 1, 3] 1 [1, 2, 3, 36] [3,2,6] 10 [-1] 📑입..
[ Programming/코딩테스트 ][프로그래머스] 서울에서 김서방 찾기2023-12-01 09:29:20▷ 해결 날짜 : 2023.12.01 ▷ 소요 시간 : 6분 ▷ 사용 언어 : 코틀린 🔎문제 : String형 배열 seoul의 element중 "Kim"의 위치 x를 찾아, "김서방은 x에 있다"는 String을 반환하는 함수, solution을 완성하세요. seoul에 "Kim"은 오직 한 번만 나타나며 잘못된 값이 입력되는 경우는 없습니다. 📑제한사항 : .seoul은 길이 1 이상, 1000 이하인 배열입니다. seoul의 원소는 길이 1 이상, 20 이하인 문자열입니다. "Kim"은 반드시 seoul 안에 포함되어 있습니다. 📑입출력 예 seoul return ["Jane", "Kim"] "김서방은 1에 있다" ⌨본인 코드 class Solution { fun solution(seoul: Arr..
[ Programming/코딩테스트 ][프로그래머스] 콜라츠 추측2023-11-30 10:30:27▷ 해결 날짜 : 2023.11.30 ▷ 소요 시간 : 40분 ▷ 사용 언어 : 코틀린 문제 : 1-1. 입력된 수가 짝수라면 2로 나눕니다. 1-2. 입력된 수가 홀수라면 3을 곱하고 1을 더합니다. 2. 결과로 나온 수에 같은 작업을 1이 될 때까지 반복합니다. 예를 들어, 주어진 수가 6이라면 6 → 3 → 10 → 5 → 16 → 8 → 4 → 2 → 1 이 되어 총 8번 만에 1이 됩니다. 위 작업을 몇 번이나 반복해야 하는지 반환하는 함수, solution을 완성해 주세요. 단, 주어진 수가 1인 경우에는 0을, 작업을 500번 반복할 때까지 1이 되지 않는다면 –1을 반환해 주세요. 제한사항 : 입력된 수, num은 1 이상 8,000,000 미만인 정수입니다. 입출력 예 n return 6..
[ Programming/코딩테스트 ][프로그래머스] 하샤드 수2023-11-29 09:37:29▷ 해결 날짜 : 2023.11.29 ▷ 소요 시간 : 7분 ▷ 사용 언어 : 코틀린 문제 : 양의 정수 x가 하샤드 수이려면 x의 자릿수의 합으로 x가 나누어져야 합니다. 예를 들어 18의 자릿수 합은 1+8=9이고, 18은 9로 나누어 떨어지므로 18은 하샤드 수입니다. 자연수 x를 입력받아 x가 하샤드 수인지 아닌지 검사하는 함수, solution을 완성해주세요. 제한사항 : x는 1 이상, 10000 이하인 정수입니다. 입출력 예 x return 10 true 12 true 11 false 13 false 입출력 예시 #1 10의 모든 자릿수의 합은 1입니다. 10은 1로 나누어 떨어지므로 10은 하샤드 수입니다. 입출력 예시 #2 12의 모든 자릿수의 합은 3입니다. 12는 3으로 나누어 떨어지..- [ Programming/코딩테스트 ][프로그래머스] 정수 내림차순으로 배치하기(코틀린)2023-11-28 10:30:33▷ 해결 날짜 : 2023.11.28 ▷ 소요 시간 : 15분 ▷ 사용 언어 : 코틀린 문제 : 함수 solution은 정수 n을 매개변수로 입력받습니다. n의 각 자릿수를 큰것부터 작은 순으로 정렬한 새로운 정수를 리턴해주세요. 예를들어 n이 118372면 873211을 리턴하면 됩니다. 제한사항 : n은 1이상 8000000000 이하인 자연수입니다. 입출력 예시 #1 n return 118372 873211 처음에 작성한 코드 class Solution { fun solution(n: Long): Long { var answer: Long = 0 var a = n.toString() var arr = a.split("").sortDescending() answer = arr.toLong() retu..