1. 모스부호 (1)function solution(letter) { let morse = { '.-': 'a', '-...': 'b', '-.-.': 'c', '-..': 'd', '.': 'e', '..-.': 'f', '--.': 'g', '....': 'h', '..': 'i', '.---': 'j', '-.-': 'k', '.-..': 'l', '--': 'm', '-.': 'n', '---': 'o', '.--.': 'p', '--.-': 'q', '.-.': 'r', '...': 's', '-': 't', '..-': 'u', '...-': 'v', '.--': 'w'..
자바스크립트

문제 영어 대소문자로 이루어진 문자열 my_string이 매개변수로 주어질 때, my_string을 모두 소문자로 바꾸고 알파벳 순서대로 정렬한 문자열을 return 하도록 solution 함수를 완성해보세요.해결 과정// 소문자로 바꾼뒤 오름차순 정렬function solution(my_string) { return my_string.toLowerCase().split('').sort().join('');} 소문자로 바꾼뒤 오름차순으로 정렬을 해서 문제를 해결하면 되었다.toLowerCase().sort()를 하니까 오류가 났다.소문자로 바꾼걸 쪼개준 뒤 다시 sort()정렬하고 join('')해줘야 오류가 안났다. join()할때는 안합쳐졌는데 join(' ')을하니 합쳐졌다.그 이유는? 🤔joi..

문제정수 n이 매개변수로 주어질 때 n의 각 자리 숫자의 합을 return하도록 solution 함수를 완성해주세요해결 과정function solution(n) { let answer = 0; let numToString = n.toString().split(''); for(i of numToString) { answer += Number(i); } return answer;} n.toString()을 이용하여 숫자를 문자열로 바꿨다. 이후 .split()을 이용하여 문자열을 문자 배열로 나눴다. 만일 "123"일 경우, ['1', '2', '3']으로 변환된다. 새롭게 알게된 점 (궁금증) for of로 접근하기 전에 기본 for문을 이용해서 풀었더니 2번째 테스트코드에서 오류가 발..

문제어떤 자연수를 제곱했을 때 나오는 정수를 제곱수라고 합니다. 정수 n이 매개변수로 주어질 때, n이 제곱수라면 1을 아니라면 2를 return하도록 solution 함수를 완성해주세요.해결 과정function solution(n) { var answer = 0; for(let i = 0; i*i return 2;를 for문 밖으로 뺀이유는 제곱수를 다 판단하고 없을 경우에 2를 반환하기 위해서이다. 새롭게 알게된 점function solution(n) { return Number.isInteger(Math.sqrt(n)) ? 1 : 2;}Number.isInteger(https://developer.mozilla.org/ko/docs/Web/JavaScript/Reference/Glob..

콜백함수함수에 파라미터로 들어가는 함수그렇다면 어떻게 사용할까? 순차적으로 실행하고 싶을때 사용한다. 콜백 함수의 원리 그렇다면 콜백함수가 왜? 필요할까? 콜백함수가 필요한 이유는 비동기 처리, 유연한 코드 구조를 위해서다.그렇다면 비동기 처리가 뭘까?자바스크립트에서는 코드가 위에서 아래로 순차적 실행이 된다. 그러나, 코드가 다른 행위가 일어난 뒤에 실행되는 경우도 있고 순차적으로 실행되지 않는 경우도 있다. 이럴때 비동기 프로그래밍이라고 한다. https://www.freecodecamp.org/korean/news/https-www-freecodecamp-org-news-javascript-callback-functions-what-are-callbacks-in-js-and-how-to-us..

문제문자열 my_string이 매개변수로 주어질 때, 대문자는 소문자로 소문자는 대문자로 변환한 문자열을 return하도록 solution 함수를 완성해주세요.해결 과정function solution(my_string) { var answer = ''; for (let i = 0; i toUpperCase와 toLowerCase를 이용하여 문제를 해결했다.

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

문제머쓱이는 친구들과 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는 숫자가 붙어있기에..

문제정수 배열 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;} 가까운 수를 구하는 문제다. 이리저리 문제를 풀 방법을 생각해 봤지만 도무지 아이디어가 안떠올라 라미개발자 영상을 보고 방법을 찾았다.그런데 문제가..