목차
반응형
문제 설명
길이가 같은 두 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 이하입니다.
나의 풀이
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를 잘 활용 해봐야겠다.
반응형