길이가 같은 두 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 |
function solution(a, b) {
var answer = 1234567890;
return answer;
}
//첫 번째 풀이
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) {
return (a.map((cur,i) => cur * b[i])).reduce((a,b) => a + b);
//map으로 a[i]*b[i] 하고 reduce로 모든 요소 합 구하기
}
문제 보고 역시 생각해내기 만만한 for문부터 돌렸다.
그리고 array 2개의 요소들끼리 곱한다고 해서 .map을, array 요소의 모든 합이라고 해서 reduce를 생각해서 두 개 합쳐서 해결.
function solution(a, b) {
return a.reduce((acc, _, i) => acc += a[i] * b[i], 0);
}