안녕하세요 (*•̀ᴗ•́*)و ̑̑
오늘도 프로그래머스에서 문제를 하나 풀어보았습니다..
쉬운 문제부터 차근차근 풀어보는게 부담이 덜하기도 하네요ㅎㅎ!
그래서 오늘 풀어본 문제는요!
[음양더하기]
어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 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함수랑 화살표 함수를 이용해서 문제를 풀었네요! @_@ 아직 익숙하지 않은 함수라 조금 더 공부 해보아야 할 것 같습니다..ㅠㅠ...
그럼 이만.....총총...
'프로그래밍 > 알고리즘' 카테고리의 다른 글
[알고리즘] 배열의 시간복잡도 (0) | 2022.07.13 |
---|---|
[알고리즘] 빅오표기법 - 1 (0) | 2022.07.08 |
[프로그래머스] 자바스크립트 코테 연습 - 3 (feat.reduce함수) (0) | 2022.06.27 |
[edabit] 자바스크립트 코테 연습 - 2 (feat.filter함수) (0) | 2022.06.23 |
[edabit] 자바스크립트 코테 연습 - 1 (feat.test함수) (0) | 2022.06.22 |