Link
Today
Total
12-23 08:10
Archives
관리 메뉴

초보개발자 긍.응.성

[Java] 8898. 3차원 농부 본문

코딩테스트/SW Expert Academy

[Java] 8898. 3차원 농부

긍.응.성 2020. 3. 20. 19:33
반응형

D4-8898. 3차원 농부

 

문제출저: https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AW45TzHae8UDFAQ7&categoryId=AW45TzHae8UDFAQ7&categoryType=CODE

 

SW Expert Academy

SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!

swexpertacademy.com

모든 위치값을 받은 후 비교하면 N*M으로 인해 시간초과가 발생한다.

최소값이 되기에 유망한 위치만 binSearch로 찾은 후 비교하여 해결하였다.

 

import java.io.BufferedWriter;
import java.io.OutputStreamWriter;
import java.util.Arrays;
import java.util.Scanner;

class Solution {
	
	public static void main(String args[]) throws Exception {

		Scanner sc = new Scanner(System.in);
		BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
		
		int T = sc.nextInt();
		int N, M;
		for (int test_case = 1; test_case <= T; test_case++) {
			N = sc.nextInt();
			M = sc.nextInt();
			int dx = Math.abs(sc.nextInt() - sc.nextInt());
			
			int[] cows = new int[N];
			for (int i = 0; i < N; i++) {
				cows[i] = sc.nextInt();
			}
			Arrays.sort(cows);
			
			int min = Integer.MAX_VALUE;
			int count = 0;
			
			for (int i = 0; i < M; i++) {
				int hPos = sc.nextInt();
				int cIdx = binSearch(cows, hPos);
				
				if (0 <= cIdx && cIdx < N) {
					int cPos = cows[cIdx];
					int dz = Math.abs(cPos - hPos);
					if (min > dz) {
						min = dz;
						count = 1;
					} else if (min == dz) {
						count++;
					}
				}
				// 이전 cows에 대해서 검사할 수 있을 때 검사
				if (0 < cIdx && cIdx < N && cows[cIdx] != hPos) {
					int cPos = cows[cIdx - 1];
					int dz = Math.abs(cPos - hPos);
					if (min > dz) {
						min = dz;
						count = 1;
					} else if (min == dz) {
						count++;
					}
					
				}
			}
				
			bw.write("#" + test_case + " " + (dx + min) + " " + count + "\n");
		}
		
		bw.flush();
		bw.close();
		
	}

	private static int binSearch(int[] arr, int value) {
		int left = 0;
		int right = arr.length - 1;
		int mid = (left + right)/2;
		
		if (value < arr[left])
			return 0;
		if (arr[right] < value) 
			return arr.length - 1;
		
		while (left <= right) {
			mid = (left + right)/2;
			
			if (arr[mid] == value) {
				return mid;
			} else if (arr[mid] < value) {
				left = mid + 1;
			} else {
				right = mid - 1;
			}
		}
		
		if (arr[mid] < value)
			mid++;
		
		return mid;
	}
}
반응형
Comments