⌨️ 프로그래머스/코딩테스트 입문 47

[프로그래머스] 한 번만 등장한 문자 | JS

문제문자열 s가 매개변수로 주어집니다. s에서 한 번만 등장하는 문자를 사전 순으로 정렬한 문자열을 return 하도록 solution 함수를 완성해보세요. 한 번만 등장하는 문자가 없을 경우 빈 문자열을 return 합니다.해결 과정문자를 사전순으로 정렬했다고 하니까 오름차순으로 정렬을 해야겠다고 생각했다.function solution(s) { var answer = ''; let sSort = s.split('').sort(); let emptyString = []; for(let i = 0; i  문제를 보고 이중for문을 이용하여 중복된 문자를 제외하고 중복되지 않은 문자를 추가하는 방향으로 생각을 했다.let sSort = s.split('').sort(); 는 문자열을 ..

[프로그래머스] 가장 큰 수 찾기 | JS

문제정수 배열 array가 매개변수로 주어질 때, 가장 큰 수와 그 수의 인덱스를 담은 배열을 return 하도록 solution 함수를 완성해보세요.해결 과정function solution(array) { var answer = []; let max = Math.max(...array); answer.push(max); let findIndexNum = array.indexOf(max); answer.push(findIndexNum); return answer;} Math.max()함수를 이용해 가장 큰 수를 찾은 다음 answer에 값을 넣었다.그 뒤 indexOf()를 이용해 인덱스 위치를 찾은 다음 answer에 값을 넣었다.리펙토링function solution(array) { ..

[프로그래머스] 배열의 유사도 | JS

문제두 배열이 얼마나 유사한지 확인해보려고 합니다. 문자열 배열 s1과 s2가 주어질 때 같은 원소의 개수를 return하도록 solution 함수를 완성해주세요.해결 과정function solution(s1, s2) { var answer = 0; for(let i = 0; i  이중for문을 이용해서 문제를 풀었다. 새롭게 알게된 점function solution(s1, s2) { const intersection = s1.filter((x) => s2.includes(x)); return intersection.length;} filter과 includes를 이용해 문제를 쉽게 풀 수 있당..

[프로그래머스] 암호 해독 | JS

문제군 전략가 머쓱이는 전쟁 중 적군이 다음과 같은 암호 체계를 사용한다는 것을 알아냈습니다.암호화된 문자열 cipher를 주고받습니다.그 문자열에서 code의 배수 번째 글자만 진짜 암호입니다.문자열 cipher와 정수 code가 매개변수로 주어질 때 해독된 암호 문자열을 return하도록 solution 함수를 완성해주세요.해결 과정function solution(cipher, code) { var answer = ''; cipher = cipher.split(''); for(let i=code-1; i 배수로 문제를 해결하려고 했는데 그렇게 접근하면 안되었다. code를 기준으로 for문을 돌려 문제를 해결했다.

[프로그래머스] 369게임 | JS

문제머쓱이는 친구들과 369게임을 하고 있습니다. 369게임은 1부터 숫자를 하나씩 대며 3, 6, 9가 들어가는 숫자는 숫자 대신 3, 6, 9의 개수만큼 박수를 치는 게임입니다. 머쓱이가 말해야하는 숫자 order가 매개변수로 주어질 때, 머쓱이가 쳐야할 박수 횟수를 return 하도록 solution 함수를 완성해보세요.해결 과정function solution(order) { var answer = 0; let count=0; let number = order.toString().replace(/\B(?=(\d{1})+(?!\d))/g, ','); for(let i = 0; i  이 문제를 처음보고 아! 숫자를 3의 배수로 나눠야겠다고 생각했다. order는 숫자가 붙어있기에..

[프로그래머스] 가까운 수 | JS

문제정수 배열 array와 정수 n이 매개변수로 주어질 때, array에 들어있는 정수 중 n과 가장 가까운 수를 return 하도록 solution 함수를 완성해주세요.해결 과정function solution(array, n) { var answer = 0; let minNum = 999; let arrayAgain = array.sort(); for (let i = 0; i Math.abs(n - num)) { minNum = Math.abs(n - num); answer = num; } } return answer;} 가까운 수를 구하는 문제다. 이리저리 문제를 풀 방법을 생각해 봤지만 도무지 아이디어가 안떠올라 라미개발자 영상을 보고 방법을 찾았다.그런데 문제가..

[프로그래머스] 삼각형의 완성조건 (1) | JS

문제선분 세 개로 삼각형을 만들기 위해서는 다음과 같은 조건을 만족해야 합니다.가장 긴 변의 길이는 다른 두 변의 길이의 합보다 작아야 합니다.삼각형의 세 변의 길이가 담긴 배열 sides이 매개변수로 주어집니다. 세 변으로 삼각형을 만들 수 있다면 1, 만들 수 없다면 2를 return하도록 solution 함수를 완성해주세요.해결 과정function solution(sides) { let organizeArray = sides.sort(); for (let i = 0; i organizeArray[2]) { return 1; } return 2; }} 오름차순이라는 힌트를 알기전까지 문제가 안풀려 좌절하고 있었다.구글링을 하기전 질문하기를 통해 오름차순의 힌트를 얻을 수 있..

[프로그래머스] 중복된 문자 제거 | JS

문제문자열 my_string이 매개변수로 주어집니다. my_string에서 중복된 문자를 제거하고 하나의 문자만 남긴 문자열을 return하도록 solution 함수를 완성해주세요.해결 과정function solution(my_string) { // (중복된 문자열을 제거한 것을) 결과로 저장할 변수 let result = ''; // my_string 순회하는 루프 for (let i = 0; i  🤔 너무 복잡하게 생각하지 말자!새롭게 알게된 점function solution(my_string) { return [...new Set(my_string)].join('');} ..., new, Set, join의 개념은 봐도봐도 헷갈린다. ... 개념정리  new 개념정리  Set 개념정리..

728x90