어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 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 해야 합니다.
public class SumPlusMinus {
// 정수를 객체로 갖는 배열과 불린값을 객체로 갖는 배열 2개를 매개변수로 받고,
// 정수를 리턴값으로 돌려주는 메소드
public int solution1(int[] absolutes, boolean[] signs) {
int answer = 0;
// 반복문을 이용하여 'signs'에 있는 불린 값들이
for (int i = 0; i < signs.length; i++) {
// 만약 i번쨰 객체가 false라면 (즉, 음수라면)
if (signs[i] == false) {
//정수 'answer'에 배열 'absolutes'의 i번째 값을 빼줌
answer -= absolutes[i];
// 배열 'signs'의 i번쨰 객체가 true라면 (즉, 양수라면)
} else {
// 'answer'에 'absolutes'의 i번째 값을 더해줌
answer += absolutes[i];
}
}
return answer;
}
public int solution2(int[] absolutes, boolean[] signs) {
int answer = 0;
for (int i=0; i<signs.length; i++)
// 배열 'absolutes'의 i번째 값을 더해주는데,
// 배열 'sign'의 i번째 가 true라면 1을 곱하고(즉, 양수를 유지하고)
// 배열 'sign'의 i번째 가 false라면 -1을 곱해줌(즉, 음수로 만듦)
answer += absolutes[i] * (signs[i]? 1: -1);
return answer;
}
public static void main(String[] args) {
SumPlusMinus sumplusminus = new SumPlusMinus();
int [] absolutes1 = {4, 7, 12};
boolean[] signs1 = {true, false, true};
int [] absolutes2 = {1, 2, 3};
boolean[] signs2 = {false, false, true};
System.out.println(sumplusminus.solution1(absolutes1, signs1)); // 9를 출력
System.out.println(sumplusminus.solution1(absolutes2, signs2)); // 0을 출력
System.out.println(sumplusminus.solution2(absolutes1, signs1)); // 9를 출력
System.out.println(sumplusminus.solution2(absolutes2, signs2)); // 0을 출력
}
}