Programmers | #Lv1 "내적"

블로그 이사 완료·2022년 9월 24일
0
post-thumbnail

문제 설명

길이가 같은 두 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 이하입니다.

입/출력 예

abresult
[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;
}

Review

내적은 서로 다른 두 수열의 자릿수 마다 곱해서 다 더한 값을 말한다.

나는 빈 숫자에 각 수열의 인덱스를 차례대로 곱해서 값을 리턴했다.

reduce() 를 사용 하는 법이 있는데
.reduce((계산값, 현재값, 인덱스) => 식, 초기값)로 사용된다.

  1. 위의 풀이에서 acc 는 계산값. 전에 계산된 게 없으니 즉 0 이다.
  2. cur 는 현재 인덱스의 값이므로 0번 인덱스부터 계산이 시작된다.
  3. idx 는 현재 인덱스의 번호다.

그러므로 두 수열이 같은 순서(같은 인덱스 번호 순)로 곱해져서 더한값을 반환 해주는 것이다.

reduce를 잘 활용 해봐야겠다.


참고 : reduce() - Mdn Web Docs

profile
https://kyledev.tistory.com/

0개의 댓글