내적

yejin·2022년 1월 17일
0

javascript 알고리즘

목록 보기
13/20

https://programmers.co.kr/learn/courses/30/lessons/70128

문제 설명

길이가 같은 두 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) {
    let result = 0;
    for (let i in a) {
        result += a[i] * b[i]
    }
    return result
}

이걸 사용했는데 for of문을 사용할려고 하니까 오류나고 for in문을 사용해야 코드가 실행됐다.
뭘까?

for ...in // 객체 순환
for ...of // 배열 값 순환

그럼 더더욱 for of문을 써야하는거 아닌가??🤔🤔 아직 미스테리다.
아무튼 for in문은 객체 순환과 배열 순환 모두 가능하다고 한다.

+for in, for of문은 쓰지않는게 좋다고 하심!!

다른풀이

function solution(a, b) {
    var answer = a.reduce((acc, cur, idx) => acc += cur*b[idx], 0)
    return answer;
}

누산기 (acc)
현재 값 (cur)
현재 인덱스 (idx)
원본 배열 (src)

리듀서 함수의 반환 값은 누산기에 할당되고, 누산기는 순회 중 유지되므로 결국 최종 결과는 하나의 값이 됩니다.

profile
♪(๑ᴖ◡ᴖ๑)♪ 기회는 도전에서부터 시작되는 것

0개의 댓글