프로그래머스 :: 예산 (JS) 문제 설명 S사에서는 각 부서에 필요한 물품을 지원해 주기 위해 부서별로 물품을 구매하는데 필요한 금액을 조사했습니다. 그러나, 전체 예산이 정해져 있기 때문에 모든 부서의 물품을 구매해 줄 수는 없습니다. 그래서 최대한 많은 부서의 물품을 구매해 줄 수 있도록 하려고 합니다. 물품을 구매해 줄 때는 각 부서가 신청한 금액만큼을 모두 지원해 줘야 합니다. 예를 들어 1,000원을 신청한 부서에는 정확히 1,000원을 지원해야 하며, 1,000원보다 적은 금액을 지원해 줄 수는 없습니다. 부서별로 신청한 금액이 들어있는 배열 d와 예산 budget이 매개변수로 주어질 때, 최대 몇 개의 부서에 물품을 지원할 수 있는지 return 하도록 solution 함수를 완성해주세요...
프로그래머스 :: 이상한 문자 만들기 (JS) 문제 설명 문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요. 제한 사항 · 문자열 전체의 짝/홀수 인덱스가 아니라, 단어 (공백을 기준) 별로 짝/홀수 인덱스를 판단해야 합니다. · 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다. 입출력 예 s return "try hello world" "TrY HeLlO WoRlD" "try hello world"는 세 단어 "try", "hello", "world"로 구성되어 있습니다. 각 단어의 짝수번째 문자를..
프로그래머스 :: 음양 더하기 (JS) 문제 설명 어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 absolutes와 이 정수들의 부호를 차례대로 담은 불리언 배열 signs가 매개변수로 주어집니다. 실제 정수들의 합을 구하여 return 하도록 solution 함수를 완성해주세요. 제한 사항 · absolutes의 길이는 1 이상 1,000 이하입니다. · absolutes의 모든 수는 각각 1 이상 1,000 이하입니다. · signs의 길이는 absolutes의 길이와 같습니다. · signs[i] 가 참이면 absolutes[i] 의 실제 정수가 양수임을, 그렇지 않으면 음수임을 의미합니다. 입출력 예 absolutes signs result [4,7,12] [true,fa..
프로그래머스 :: 제일 작은 수 제거하기 (JS) 문제 설명 정수를 저장한 배열, 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) { return (arr.length === 1 ? [-1] : arr.filter((nu..
프로그래머스 :: 로또의 최고 순위와 최저 순위 (JS) 문제 설명 로또 6/45 (이하 '로또'로 표기)는 1부터 45까지의 숫자 중 6개를 찍어서 맞히는 대표적인 복권입니다. 아래는 로또의 순위를 정하는 방식입니다. 순위 당첨 내용 1 6개 번호 모두 일치 2 5개 번호 일치 3 4개 번호 일치 4 3개 번호 일치 5 2개 번호 일치 6(낙첨) 그 외 로또를 구매한 민우는 당첨 번호 발표일을 학수고대하고 있었습니다. 하지만, 민우의 동생이 로또에 낙서를 하여, 일부 번호를 알아볼 수 없게 되었습니다. 당첨 번호 발표 후, 민우는 자신이 구매했던 로또로 당첨이 가능했던 최고 순위와 최저 순위를 알아보고 싶어 졌습니다. 알아볼 수 없는 번호를 0 으로 표기하기로 하고, 민우가 구매한 로또 번호 6개가 4..
자바스크립트 반복문 정리하기 반복문은 한 동작을 여러 번 반복한다. 자바스크립트가 지원하는 반복문은 8가지이다. 1. for 문 for 반복문은 어떤 특정한 조건이 거짓으로 판별될 때까지 반복한다. for ([초기문]; [조건문]; [증감문]) 문장 ✔️ 초기문이 존재하면 초기문이 실행된다. 보통 1이나 반복문 카운터로 초기 설정이 된다. 복잡한 구문이나 변수로 선언되기도 한다. ✔️ 조건문은 조건을 검사한다. 만약 조건문이 참이라면, 그 반복문은 실행된다. 만약 조건문이 거짓이라면 그 for 문은 종결된다. 만약 그 조건문이 생략된다면, 참으로 추정된다. ✔️ 갱신 구문인 증감문이 존재한다면 실행되고 2번째 단계로 돌아간다. 2. do...while 문 do...while 문은 특정한 조건이 거짓으로 ..
프로그래머스 :: 완주하지 못한 선수 (JS) 문제 설명 수많은 마라톤 선수들이 마라톤에 참여하였습니다. 단 한 명의 선수를 제외하고는 모든 선수가 마라톤을 완주하였습니다. 마라톤에 참여한 선수들의 이름이 담긴 배열 participant와 완주한 선수들의 이름이 담긴 배열 completion이 주어질 때, 완주하지 못한 선수의 이름을 return 하도록 solution 함수를 작성해주세요. 제한사항 · 마라톤 경기에 참여한 선수의 수는 1명 이상 100,000명 이하입니다. · completion의 길이는 participant의 길이보다 1 작습니다. · 참가자의 이름은 1개 이상 20개 이하의 알파벳 소문자로 이루어져 있습니다. ·참가자 중에는 동명이인이 있을 수 있습니다. 입출력 예 participa..
프로그래머스 :: 문자열 다루기 기본 (JS) 문제 설명 문자열 s의 길이가 4 혹은 6이고, 숫자로만 구성돼있는지 확인해주는 함수, solution을 완성하세요. 예를 들어 s가 "a234" 이면 False를 리턴하고 "1234" 라면 True를 리턴하면 됩니다. 제한 사항 · s는 길이 1 이상, 길이 8 이하인 문자열입니다. · s는 영문 알파벳 대소문자 또는 0부터 9까지 숫자로 이루어져 있습니다. 입출력 예 s return "a234" false "1234" true 문제 풀이 function solution(s) { if (String(s).length === 4 || String(s).length === 6) { for (let i = 0; i < String(s).length; i++){ ..
K번째수 문제 설명 배열 array의 i번째 숫자부터 j번째 숫자까지 자르고 정렬했을 때, k번째에 있는 수를 구하려 합니다. 예를 들어 array가 [1, 5, 2, 6, 3, 7, 4], i = 2, j = 5, k = 3이라면 · array의 2번째부터 5번째까지 자르면 [5, 2, 6, 3]입니다. · 1에서 나온 배열을 정렬하면 [2, 3, 5, 6]입니다. · 2에서 나온 배열의 3번째 숫자는 5입니다. 배열 array, [i, j, k]를 원소로 가진 2차원 배열 commands가 매개변수로 주어질 때, commands의 모든 원소에 대해 앞서 설명한 연산을 적용했을 때 나온 결과를 배열에 담아 return 하도록 solution 함수를 작성해주세요. 제한사항 · array의 길이는 1 이상..
프로그래머스 :: 두 개 뽑아서 더하기 (JS) 문제 설명 정수 배열 numbers가 주어집니다. numbers에서 서로 다른 인덱스에 있는 두 개의 수를 뽑아 더해서 만들 수 있는 모든 수를 배열에 오름차순으로 담아 return 하도록 solution 함수를 완성해주세요. 제한사항 · numbers의 길이는 2 이상 100 이하입니다. · numbers의 모든 수는 0 이상 100 이하입니다. 입출력 예 number result [2,1,3,4,1] [2,3,4,5,6,7] [5,0,2,7] [2,5,7,9,12] 문제 풀이 function solution(numbers, result = []) { for (let i = 0; i < numbers.length; i++) { for (let j = i ..