[프로그래머스 / JAVA] Level 1 음양 더하기 (76501)
⏰ 2021-12-14 (화) 17:01:15
음양 더하기
랭크 | 사용 언어 |
---|---|
Level 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 |
입출력 예 설명
입출력 예 #1
signs
가 { true, false, true } 이므로, 실제 수들의 값은 각각 4, -7, 12입니다.
따라서 세 수의 합인 9를 return 해야 합니다.
입출력 예 #2
signs
가 { false, false, true } 이므로, 실제 수들의 값은 각각 -1, -2, 3입니다.
따라서 세 수의 합인 0을 return 해야 합니다.
풀이
absolutes
는 수의 절대값을, signs
은 수의 부호를 가진다. 인덱스별로 각 요소를 호출하여 signs
의 값에 따라 absolutes
를 가감하면 될 것이다.
absolutes
와 signs
크기는 동일하므로, 어떤 배열을 인덱스로 삼든 상관 없다.
JAVA
1 2 3 4
for (int i = 0; i < absolutes.length; i++) { answer += (signs[i] ? absolutes[i] : -absolutes[i]); }
signs[i]
의 값에 따라 absolutes
를 가감하여 answer
에 누적시키면 된다.
코드
JAVA
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
/** * 음양 더하기 클래스 * * @author RWB * @since 2021.12.10 Fri 00:09:32 */ class Solution { /** * 해답 반환 메서드 * * @param absolutes: [int[]] 정수 절대값 배열 * @param signs: [boolean[]] 정수의 부호 * * @return [int] 해답 */ public int solution(int[] absolutes, boolean[] signs) { int answer = 0; for (int i = 0; i < absolutes.length; i++) { answer += (signs[i] ? absolutes[i] : -absolutes[i]); } return answer; } }
🏷️ 태그
# 프로그래머스
# 알고리즘
# JAVA(자바)
# Level 1
읽어주셔서 고마워요!
도움이 되셨다면, 공감이나 댓글을 달아주시는 건 어떤가요?
블로그 운영에 큰 힘이 됩니다.