[프로그래머스] Lv.1 음양 더하기 (JS)

아름·2023년 11월 29일
0

알고리즘

목록 보기
13/26

🔎 문제

어떤 정수들이 있습니다.
이 정수들의 절댓값을 차례대로 담은 정수 배열 absolutes와 이 정수들의 부호를 차례대로 담은 불리언 배열 signs가 매개변수로 주어집니다.
실제 정수들의 합을 구하여 return 하도록 solution 함수를 완성해주세요.

absolutes의 길이는 1 이상 1,000 이하입니다.
absolutes의 모든 수는 각각 1 이상 1,000 이하입니다.
signs의 길이는 absolutes의 길이와 같습니다.
signs[i] 가 참이면 absolutes[i] 의 실제 정수가 양수임을, 그렇지 않으면 음수임을 의미합니다. 

입출력 예


🔓 풀이 과정

고민

1) 배열을 다 더해줘야하니까 일단 for문 활용하기 // absolutes의 배열 돌리기
2) 배열이 1개 이상일 때는 어떻게 해야할까..?
3) sign의 부호가 +라면 더하고, -라면 빼기 // if else 사용

나의 풀이

function solution(absolutes, signs) {
  let answer = 0;
  for (let i = 0; i < absolutes.length; i++) {
    if (signs[i] === true) {
      answer = answer + absolutes[i];
    } else {
      answer = answer - absolutes[i];
    }
  }
  return answer;
}

그 밖의 풀이

function solution(absolutes, signs) {

    return absolutes.reduce((acc, val, i) => acc + (val * (signs[i] ? 1 : -1)), 0);
}

reduce 메소드
array1.reduce(a, b, i)
a : 누적값
b : 현재값 (reduce를 호출한 배열의 요소값)
i : index (reduce를 호출한 배열의 요소값의 index)

profile
내 꿈은 개발자

0개의 댓글