JS코딩테스트
[JS코테] 월간 코드 챌린지 시즌1
DaeunCoding
2023. 4. 24. 09:25
728x90
반응형
https://school.programmers.co.kr/learn/courses/30/lessons/70128
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
[나의 풀이]
function solution(a, b) {
let answer = [];
for(i=0;i<a.length;i++){
answer.push(i);
}
return answer.map(x => a[x]*b[x]).reduce((a,b) => a+b);
}
1) 빈 배열 answer 선언
2) for문으로 a의 길이만큼 0부터 a.length-1까지 배열answer에 추가
3) map으로 index가 0부터 a.length-1까지의 a와 b 요소를 곱함
4) reduce로 모든 요소 더함
[다른 풀이]
function solution(a, b) {
return a.reduce((acc, _, i) => acc += a[i] * b[i], 0);
}
내가 푼 방식에서는 for문이 불필요하게 있는데,
이 방식에서는 reduce를 좀 더 활용해서 for문을 쓸 필요가 없게 풀어내었다.
currentValue값이 필요가 없고, index가 필요해서 매개변수 의 두 번째 칸을 _로 처리한 후, 세 번째 칸에 i를 넣어주었다.
728x90
반응형