문제
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
정답
function solution(n) {
// n 길이의 배열을 만든다
// 배열을 1로 채운다
// map의 인덱스를 이용해 1부터 n까지의 배열로 바꾼다
// 배열의 값이 n으로 나누어 떨어지면 약수
return Array(n)
.fill(1)
.map((a, b) => a + b)
.filter(x => n % x === 0);
}
// for문을 이용하는 방식으로, 원리는 정답1과 동일하다
function solution(n) {
const answer = [];
for (let i = 1; i <= n; i++) {
if (n % i === 0) answer.push(i);
}
return answer;
}
function solution(n) {
let index = 1;
let answer = [];
while (index <= n) {
if (n % index == 0) {
answer.push(index);
}
index += 1;
}
return answer;
}