어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 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
- signs가
[true,false,true]
이므로, 실제 수들의 값은 각각 4, -7, 12입니다.- 따라서 세 수의 합인 9를 return 해야 합니다.
입출력- signs가
[false,false,true]
이므로, 실제 수들의 값은 각각 -1, -2, 3입니다.- 따라서 세 수의 합인 0을 return 해야 합니다.
class Solution {
public int solution(int[] absolutes, boolean[] signs) {
int answer = 0;
for(int i=0; i<absolutes.length; i++){
for(int j=i; j<=i; j++){
if(signs[j] == false){
absolutes[j] *= -1;
}
}
answer += absolutes[i];
}
return answer;
}
}
class Solution {
public int solution(int[] absolutes, boolean[] signs) {
int answer = 0;
for (int i=0; i<signs.length; i++)
answer += absolutes[i] * (signs[i]? 1: -1);
return answer;
}
}
class Solution {
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;
}
}
class Solution {
public int solution(int[] absolutes, boolean[] signs) {
int answer = 0;
for(int i = 0; i < signs.length; i++){
if(signs[i]){
answer += absolutes[i];
} else {
answer -= absolutes[i];
}
}
return answer;
}
}
나는 이중 for문을 썼는데 그럴 필요가 없었다 그냥 for문 하나로 할 수 있는 걸 왜 이중for문을 썼을까 근데 안에 있는 내용도 j=i; j<=i라고 하면 그냥 바깥 for문이랑 같은 내용인데 바보같다 헤헤..
깔끔하게 한줄로 나타낼수도 있고 훨씬 좋은게 많았다!! 나도 저렇게 해야지 다시 풀어볼게~!~!