프로그래머스 1단계 : 내적
코딩테스트 연습 > 연습문제 > 내적
✔ 문제 설명
길이가 같은 두 1차원 정수 배열 a, b가 매개변수로 주어집니다. a와 b의 내적을 return 하도록 solution 함수를 완성해주세요. 이때, a와 b의 내적은 a[0]*b[0] + a[1]*b[1] + ... + a[n-1]*b[n-1] 입니다. (n은 a, b의 길이)
✔ 제한 사항
a, b의 길이는 1 이상 1,000 이하입니다.
a, b의 모든 수는 -1,000 이상 1,000 이하입니다.
✔ 입출력 예
a | b | result |
---|---|---|
[1,2,3,4] | [-3,-1,0,2] | 3 |
[-1,0,1] | [1,0,-1] | -2 |
✔ 문제풀이
function solution(a, b) {
let answer = 0;
for(i in a){
answer += a[i] * b[i];
}
return answer;
}
// console.log(solution([1,2,3],[-1,2,-3]))
✔ 설명
덧셈인줄알고 어디가 틀린지 계속 돌려봤네요 너무 쉽죠?
✔ 다른사람의 풀이
return a.reduce((acc, _, i) => acc += a[i] * b[i], 0);
reduce메서드에 대한 이해만 있다면 한줄로 쓸수 있군요.
댓글