문제 설명 새로 생긴 놀이기구는 인기가 매우 많아 줄이 끊이질 않습니다. 이 놀이기구의 원래 이용료는 price원 인데, 놀이기구를 N 번 째 이용한다면 원래 이용료의 N배를 받기로 하였습니다. 즉, 처음 이용료가 100이었다면 2번째에는 200, 3번째에는 300으로 요금이 인상됩니다. 놀이기구를 count번 타게 되면 현재 자신이 가지고 있는 금액에서 얼마가 모자라는지를 return 하도록 solution 함수를 완성하세요. 단, 금액이 부족하지 않으면 0을 return 하세요. 제한사항 놀이기구의 이용료 price : 1 ≤ price ≤ 2,500, price는 자연수 처음 가지고 있던 금액 money : 1 ≤ money ≤ 1,000,000,000, money는 자연수 놀이기구의 이용 횟수 c..
문제 설명 문자열 s에 나타나는 문자를 큰것부터 작은 순으로 정렬해 새로운 문자열을 리턴하는 함수, solution을 완성해주세요. s는 영문 대소문자로만 구성되어 있으며, 대문자는 소문자보다 작은 것으로 간주합니다. 제한사항 s는 길이 1 이상인 문자열입니다. 입출력 예 s가 "Zbcdefg"일 때 "gfedcbZ"를 return 풀이 function solution(s) { let characters = s.split(''); let lowerCaseChars = []; let upperCaseChars = []; for(let i = 0; i < characters.length; i++) { if(characters[i] === characters[i].toUpperCase()) { upperCas..
문제 설명 두 정수 left와 right가 매개변수로 주어집니다. left부터 right까지의 모든 수들 중에서, 약수의 개수가 짝수인 수는 더하고, 약수의 개수가 홀수인 수는 뺀 수를 return 하도록 solution 함수를 완성해주세요. 제한사항 1 ≤ left ≤ right ≤ 1,000 입출력 예 left가 13, right가 17로 주어졌을 때 13부터 17까지 각각의 약수의 개수는 아래와 같다. 13 1, 13 2 14 1, 2, 7, 14 4 15 1, 3, 5, 15 4 16 1, 2, 4, 8, 16 5 17 1, 17 2 => 13 + 14 + 15 - 16 + 17 = 43을 return 하면 된다. 풀이 function solution(left, right) { let arr = ..
문제 설명 어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 absolutes와 이 정수들의 부호를 차례대로 담은 불리언 배열 signs가 매개변수로 주어집니다. 실제 정수들의 합을 구하여 return 하도록 solution 함수를 완성해주세요. 제한사항 absolutes의 길이는 1 이상 1,000 이하입니다. absolutes의 모든 수는 각각 1 이상 1,000 이하입니다. signs의 길이는 absolutes의 길이와 같습니다. signs[i] 가 참이면 absolutes[i] 의 실제 정수가 양수임을, 그렇지 않으면 음수임을 의미합니다. 입출력 예 absolutes가 [4,7,12] 이고, signs가 [true, false, true] 일 때, 실제 수들의 값은 각각 4,..
문제 설명 자연수 N이 주어지면, N의 각 자릿수의 합을 구해서 return 하는 solution 함수를 만들어 주세요. 예를들어 N = 123이면 1 + 2 + 3 = 6을 return 하면 됩니다. 제한사항 N의 범위 : 100,000,000 이하의 자연수 입출력 예 N이 123일 때 1+ 2+ 3 이므로 6을 return N이 987일 때 9+8+7 이므로 24를 return 풀이 function solution(n) { const digits = n.toString().split(''); const sumOfDigits = digits.reduce((prev, curr) => prev + parseInt(curr), 0); return sumOfDigits; } 설명 -n을 먼저 string 타입..
문제 설명 함수 solution은 정수 x와 자연수 n을 입력 받아, x부터 시작해 x씩 증가하는 숫자를 n개 지니는 리스트를 리턴해야 합니다. 다음 제한 조건을 보고, 조건을 만족하는 함수, solution을 완성해주세요. 제한사항 x는 -10000000 이상, 10000000 이하인 정수입니다. n은 1000 이하인 자연수입니다. 입출력 예 x가 2이고, n이 5일 때 [2,4,6,8,10]을 return x가 4이고, n이 3일 때 [4,8,12]를 return x가 -4이고, n이 2일 때 [-4, -8]을 return 풀이 function solution(x, n) { let arr = []; for(i = 1; i
문제 설명 정수 n을 입력받아 n의 약수를 모두 더한 값을 리턴하는 함수, solution을 완성해주세요. 제한사항 n은 0 이상 3000이하인 정수입니다. 입출력 예 n이 12일 때 약수는 (1, 2, 3, 4, 6, 12) 입니다. 이를 모두 더하면 28 입니다. n이 5일 때 약수는 (1, 5) 입니다. 이를 모두 더하면 6 입니다. 풀이 function solution(n) { let arr = []; for(i = 1; i prev + curr, 0); } 설명 -먼저 arr라는 빈 배열을 준비한다. -약수는 n을 1부터 n까지 나눴을 때 나머지가 0이 되는 숫자를 뜻한다. 그러므로 반복문을 통해 n을 1부터 n까지 하나씩 나눠주면서 나머지가 0이 되는 값을 arr에 push 하도록 하면 된다...