본문 바로가기

프로그래밍/알고리즘

[프로그래머스] 자바스크립트 코테 연습 - 4 (feat.reduce함수)

안녕하세요 (*•̀ᴗ•́*)و ̑̑

 

 

오늘도 프로그래머스에서 문제를 하나 풀어보았습니다..

 

 

쉬운 문제부터 차근차근 풀어보는게 부담이 덜하기도 하네요ㅎㅎ!

 

 

그래서 오늘 풀어본 문제는요!

 

 

[음양더하기]

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


[제한사항]

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

[입출력 예]

absolutes            signs                 result
[4,7,12]         [true,false,true]          9
[1,2,3]           [false,false,true]         0

 

 

 

위의 문제 처럼 false일 경우 해당 배열의 값은 - 라는 말! 그래서 작성해본 코드는 

 

 

 

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

    return answer;
}

 

 

signs의 i 번째 값이 false 라면 answer에는 aboslutes의 i 번째 값에 마이너스를 더해서 answer 추가해주고 아닐경우에는 answer에 바로 해당값을 더해주며 for문을 돌았습니다.

 

 

 

 

 

 

 

그리고 이렇게 작성한 코드는 쉽게 테스트를 통과했습니다!

 

그럼 이제 제일 기대되는 다른 사람의 코드!!!

 

 

function solution(absolutes, signs) {

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

 

 

 

 

reduce함수랑 화살표 함수를 이용해서 문제를 풀었네요!  @_@ 아직 익숙하지 않은 함수라 조금 더 공부 해보아야 할 것 같습니다..ㅠㅠ...

 

 

그럼 이만.....총총...