공부/코딩테스트 52

Q. 특정 문자 제거하기

문자열 my_string과 문자 letter이 매개변수로 주어집니다. my_string에서 letter를 제거한 문자열을 return하도록 solution 함수를 완성해주세요. 🚫제한 사항 1 ≤ my_string의 길이 ≤ 100 letter은 길이가 1인 영문자입니다. my_string과 letter은 알파벳 대소문자로 이루어져 있습니다. 대문자와 소문자를 구분합니다. ❗입출력 예 my_string letter result "agcdef" "f" "abcde" "BCBdbe" "B" "Cdbe" 😀 내가 푼 답 const solution = (my_string, letter) => my_string.replaceAll(letter, ""); replaceAll() 문자열에서 특정 문자를 지정한 문자열..

Q. 편지

머쓱이는 할머니께 생신 축하 편지를 쓰려고 합니다. 할머니가 보시기 편하도록 글자 한 자 한 자를 가로 2cm 크기로 적으려고 하며, 편지를 가로로만 적을 때, 축하 문구 message를 적기 위해 필요한 편지지의 최소 가로길이를 return 하도록 solution 함수를 완성해주세요. 🚫제한 사항 공백도 하나의 문자로 취급합니다. 1 ≤ message의 길이 ≤ 50 편지지의 여백은 생각하지 않습니다.message는 영문 알파벳 대소문자, ‘!’, ‘~’ 또는 공백으로만 이루어져 있습니다. ❗입출력 예 message result "happy birthday!" 30 "I love you~" 22 😀 내가 푼 답 const solution = message => message.length * 2 😊 문제..

Q. 같은 숫자는 싫어

배열 arr가 주어집니다. 배열 arr의 각 원소는 숫자 0부터 9까지로 이루어져 있습니다. 이때, 배열 arr에서 연속적으로 나타나는 숫자는 하나만 남기고 전부 제거하려고 합니다. 단, 제거된 후 남은 수들을 반환할 때는 배열 arr의 원소들의 순서를 유지해야 합니다. 예를 들면, arr = [1, 1, 3, 3, 0, 1, 1] 이면 [1, 3, 0, 1] 을 return 합니다. arr = [4, 4, 4, 3, 3] 이면 [4, 3] 을 return 합니다. 배열 arr에서 연속적으로 나타나는 숫자는 제거하고 남은 수들을 return 하는 solution 함수를 완성해 주세요. 🚫제한 사항 배열 arr의 크기 : 1,000,000 이하의 자연수 배열 arr의 원소의 크기 : 0보다 크거나 같고 9..

Q. 최소 직사각형

명함 지갑을 만드는 회사에서 지갑의 크기를 정하려고 합니다. 다양한 모양과 크기의 명함들을 모두 수납할 수 있으면서, 작아서 들고 다니기 편한 지갑을 만들어야 합니다. 이러한 요건을 만족하는 지갑을 만들기 위해 디자인팀은 모든 명함의 가로 길이와 세로 길이를 조사했습니다. 아래 표는 4가지 명함의 가로 길이와 세로 길이를 나타냅니다. 명함 번호 가로 길이 세로 길이 1 60 50 2 30 70 3 60 30 4 80 40 가장 긴 가로 길이와 세로 길이가 각각 80, 70이기 때문에 80(가로) x 70(세로) 크기의 지갑을 만들면 모든 명함들을 수납할 수 있습니다. 하지만 2번 명함을 가로로 눕혀 수납한다면 80(가로) x 50(세로) 크기의 지갑으로 모든 명함들을 수납할 수 있습니다. 이때의 지갑 크..

Q. 3진법 뒤집기

자연수 n이 매개변수로 주어집니다. n을 3진법 상에서 앞뒤로 뒤집은 후, 이를 다시 10진법으로 표현한 수를 return 하도록 solution 함수를 완성해주세요. 🚫제한 사항 n은 1 이상 100,000,000 이하인 자연수입니다. ❗입출력 예 n result 45 7 125 229 😀 내가 푼 답 function solution(n) { return parseInt(n.toString(3).split("").reverse().join(""), 3) } ⅰ. 10진수 -> n진수로 진수 변환하기 toString() toString()은 문자열을 반환하는 object의 대표적이 방법이지만 기수(radix)를 매개변수로 취할시에는 10진수를 다른 진수로 변환할 수 있음 기수의 값은 최소 2부터 36까지..

Q. 하샤드 수

양의 정수 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 😀 내가 푼 답 function solution(x) { let num = 0 const sum = (x + "").split("").reduce((acc, curr) => acc + parseInt(curr), 0) return x % sum === 0 ? true : false } ..

Q. 콜라츠 추측

1937년 Collatz란 사람에 의해 제기된 이 추측은, 주어진 수가 1이 될 때까지 다음 작업을 반복하면, 모든 수를 1로 만들 수 있다는 추측입니다. 작업은 다음과 같습니다. 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을 반환해 주세요. 🚫제한 사항 입력된 수, ..

Q. 제일 작은 수 제거하기

정수를 저장한 배열, 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] 😀 내가 푼 답 function solution(arr) { if (arr.length idx !== min_idx); } 😊 문제풀이 답안 OR 다른사람들 답안 // 1 function solutio..

Q. 정수 제곱근 판별

임의의 양의 정수 n에 대해, n이 어떤 양의 정수 x의 제곱인지 아닌지 판단하려 합니다. n이 양의 정수 x의 제곱이라면 x+1의 제곱을 리턴하고, n이 양의 정수 x의 제곱이 아니라면 -1을 리턴하는 함수를 완성하세요. 🚫제한 사항 n은 1이상, 50000000000000 이하인 양의 정수입니다. ❗입출력 예 n return 121 144 3 -1 😀 내가 푼 답 📜 Math.sqrt(n)을 통해 주어진 정수 n의 제곱근을 계산하고 Math.sqrt(n) % 1 === 0을 통해 제곱근이 정수인지 확인 % 연산자를 사용하여 제곱근을 1로 나눈 나머지가 0인지 확인(정수일 경우 Math.sqrt(n) % 1은 0을 리턴함) Math.pow(Math.sqrt(n) + 1, 2)를 계산하여 제곱근 + 1 ..

Q. 정수 내림차순으로 배치하기

함수 solution은 정수 n을 매개변수로 입력받습니다. n의 각 자릿수를 큰것부터 작은 순으로 정렬한 새로운 정수를 리턴해주세요. 예를들어 n이 118372면 873211을 리턴하면 됩니다. 🚫제한 사항 n은 1이상 8000000000 이하인 자연수입니다. ❗입출력 예 n return 118372 873211 😀 내가 푼 답 function solution(n) { return Number( (n + "") .split("") .sort((x, y) => y - x) .join("") ); } 😊 문제풀이 답안 OR 다른사람들 답안 function solution(n) { const newN = n + ""; const newArr = newN .split("") .sort() .reverse() ...