풀이 function solution(s) { if(s.length===4 || s.length===6){ const temp = parseInt(s); if(temp==s){ return true; }else{ return false; } }else{ return false; } } function solution(s) { if((s.length == 4 || s.length == 6) && /^[0-9]+$/.test(s)) { return true; }else{ return false; } } 위는 int형으로 바꿔서 비교하는 코드이고 아래는 정규식을 이용한 코드이다.
풀이 function solution(s) { return s.split('').sort().reverse().join(''); } split은 저번 문제에 나와서 알고 있었다. 조만간 split, splice같은 비슷한 맥락의 함수를 정리해서 올리겠다. reverse라는 함수가 있는지 오늘 처음알았다. 그전에는 if문이나 삼항연산자로 역순을 만들어야 했는데 이런방법도 있구나 싶었다. join은 배열을 문자열로 변환하는 함수이다. 즉 정리하면 split으로 문자열을 배열로 만들고 sort로 정렬하고 reverse로 역순정렬하고 join으로 다시 배열을 문자열로 합치는 식이다.
풀이 function solution(arr, divisor) { for(let i=0;i{ return a-b; }) if(answer.length===0){ answer.push(-1) } return answer; } function solution(arr, divisor) { let answer = []; arr.map((i) => { i % divisor === 0 && answer.push(i); }) return answer.length ? answer.sort((a, b) => a - b) : [-1]; } 위는 map과 삼항연산자를 사용하지 않은 경우이고 밑에는 map과 삼항연산자로 같은 코드이지만 조금 더 깔끔하게 표현한 경우이다. 저번 글에서도 올렸는데 숫자비교를 할때는 sort를 저..