위의 용액 합성하기 문제와 거의 같은 문제이다.
가장 0과 가까운 수를 찾았을 때 왼쪽과 오른쪽 용액을 저장해 두고 출력하면 된다.
import java.io.*;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws NumberFormatException, IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(br.readLine());
int[] arr = new int[N];
StringTokenizer st = new StringTokenizer(br.readLine());
for (int i = 0; i < N; i++) {
arr[i] = Integer.parseInt(st.nextToken());
}
int left = 0;
int right = N-1;
int resL = 0, resR = 0;
int min = Integer.MAX_VALUE;
while(true) {
if(left==right) break;
int sum = arr[left] + arr[right];
if(Math.abs(sum) <= min) {
min = Math.abs(sum);
resL = arr[left];
resR = arr[right];
}
if(sum < 0) {
left++;
} else {
right--;
}
}
System.out.println(resL + " " + resR);
}
}
[참고]
값이 오름차순으로 들어오지 않는 유형의 문제이다.
'Algorithm > Baekjoon Online Judge' 카테고리의 다른 글
[Java] BOJ2473_세 용액 (0) | 2021.04.20 |
---|---|
[Java] BOJ2470_두 용액 (0) | 2021.04.20 |
[Java] BOJ14921_용액 합성하기 (0) | 2021.04.19 |
[Java] BOJ14890_경사로 (0) | 2021.04.19 |
[Java] BOJ14888_연산자 끼워넣기 (0) | 2021.04.19 |