본문 바로가기
알고리즘

7. 음양 더하기 (JavaScript)

by 프잘백 2022. 1. 15.
728x90

문제 설명

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

 

 

제한사항

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

 

 입출력 예시

 

입출력 예 설명

 

입출력 예 #1

  • signs가 [true,false,true] 이므로, 실제 수들의 값은 각각 4, -7, 12입니다.
  • 따라서 세 수의 합인 9를 return 해야 합니다.

입출력 예 #2

  • signs가 [false,false,true] 이므로, 실제 수들의 값은 각각 -1, -2, 3입니다.
  • 따라서 세 수의 합인 0을 return 해야 합니다.

 

 

나의 풀이

 

function solution(absolutes, signs) {
    const newsigns = signs.map(sign=> sign ? 1 : -1); // 삼항 연산을 이용해 부호를 끄집어 냈다
    const answer = absolutes.map(function(aaa, i){return aaa * newsigns[i]} ); //길이가 같은 두 배열의 요소들간의 곱
    const summary = (x, z) => x + z; //합계 함수 만들기 ★reduce★
    return answer.reduce(summary); // 합계 출력
    return answer
}

 

1. signs의 각 요소들을 삼항 연산을 통해 newsigns에 차례로 찍히도록 mapping 했다.

2. 길이가 같은 두 배열의 요소들이 차례로 곱해지도록 mapping 했다.

3. 지난 포스팅의 reduce( ) 를 그대로 들고왔다.

4. 성공

두 배열간의 곱이 힘들었다..

 

 

모범 답안

 

function solution(absolutes, signs) {

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

 

역시 reduce( ) 는 대단하다 ;;

 

 

map( )


map( )을 더 알아보고 싶다.

일단 사용법은 다음과 같다.

배열.map((요소, 인덱스, 배열) => { return 요소 });

map의 기본 원리는 간단하다. 반복문을 돌며 배열 안의 요소들을 1대1로 짝지어 준다.

 

예시는 다음과 같다.

생각보다 간단한데 막상 사용하려면 ..ㅠ

댓글