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];
조금 더 생각해보고 고민해보면 좋았을 것을!
공부.. 공부...
'리코딩 : 알고리즘' 카테고리의 다른 글
11. 프로그래머스 - [카카오]비밀지도 (0) | 2021.10.01 |
---|---|
10. 프로그래머스 - 신규 아이디 추천 (0) | 2021.09.28 |
8. 프로그래머스 - 로또의 최고 순위와 최저 순위 (0) | 2021.09.24 |
7. 프로그래머스 - 124나라의 숫자 (0) | 2021.09.23 |
6. 프로그래머스 - 나누어 떨어지는 숫자 배열 (0) | 2021.09.16 |