리코딩 : 알고리즘

9. 프로그래머스 - 음양더하기

BreezeBm 2021. 9. 25. 23:00

1. 문제

문제 설명

어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 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

2. 나의 풀이

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

- 절댓값과 부호의 갯수는 같다.

- 반복문을 통해서 부호를 기준으로 분기를 해서, true인 경우에는 값을 더해주고, false인 경우에는 값을 빼준다.

 

 제일 먼저 반복문과 if문을 사용해서 문제를 풀 수 있을 것 같았다. 하지만 이전부터 계속 봐온 삼항 연산자를 사용해 보고 싶어서, 다시 한번 코드를 작성했고, 통과를 했다.

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

 signs의 값이 참(true)인 경우에는 값을 더해주고, 거짓(false)인 경우에는 값을 빼주는 것으로 코드를 작성했다.

 

 다른 분의 풀이를 보니 삼항 연산자로 접근 하신 분들이 많았고, 조금 더 간결하게 작성하셨다.

signs[i] ? answer += absolutes[i] : answer -= abosolutes[i];

 조금 더 생각해보고 고민해보면 좋았을 것을!

 

공부.. 공부...