길이가 같은 두 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 | result |
---|---|---|
[1,2,3,4] | [-3,-1,0,2] | 3 |
[-1,0,1] | [1,0,-1] | -2 |
입출력 예 #1
a와 b의 내적은 1(-3) + 2(-1) + 30 + 42 = 3 입니다.
입출력 예 #2
a와 b의 내적은 (-1)1 + 00 + 1*(-1) = -2 입니다.
function solution(a, b) {
var answer = 0;
for(let i=0; i<a.length;i++){
answer += a[i]*b[i]
}
return answer;
}
function solution(a, b) {
var answer = a.reduce((acc, cur, idx) => acc += cur*b[idx], 0)
return answer;
}
내적은 서로 다른 두 수열의 자릿수 마다 곱해서 다 더한 값을 말한다.
나는 빈 숫자에 각 수열의 인덱스를 차례대로 곱해서 값을 리턴했다.
reduce()
를 사용 하는 법이 있는데
.reduce((계산값, 현재값, 인덱스) => 식, 초기값)로 사용된다.
acc
는 계산값. 전에 계산된 게 없으니 즉 0
이다.cur
는 현재 인덱스의 값이므로 0번 인덱스부터 계산이 시작된다.idx
는 현재 인덱스의 번호다.그러므로 두 수열이 같은 순서(같은 인덱스 번호 순)로 곱해져서 더한값을 반환 해주는 것이다.
reduce를 잘 활용 해봐야겠다.