백준 7795 먹을 것인가 먹힐 것인가 Java

: ) YOUNG·2024년 1월 15일
1

알고리즘

목록 보기
295/411
post-thumbnail

백준 7795번
https://www.acmicpc.net/problem/7795

문제



생각하기


  • lowerBound를 통해서 인덱스를 찾으면 된다.
    • 자기보다 작거나 같은 값의 인덱스를 반환한다.

동작



결과


코드



import java.io.*;
import java.util.Arrays;
import java.util.StringTokenizer;

public class Main {

    // input
    private static BufferedReader br;

    // variables
    private static int N, M;
    private static int[] aArr, bArr;

    public static void main(String[] args) throws IOException {
        br = new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

        int t = Integer.parseInt(br.readLine());
        while (t-- > 0) {
            input();

            bw.write(solve());
        }

        bw.close();
    } // End of main()

    private static String solve() {
        StringBuilder sb = new StringBuilder();

        int ans = 0;
        for (int i = 0; i < N; i++) {
            int num = aArr[i];
            ans += lowerBound(0, M, num); // 가지고 있는 값 또는 num 보다 낮은 값의 인덱스 반환
        }

        sb.append(ans).append('\n');
        return sb.toString();
    } // End of solve()

    private static int lowerBound(int low, int high, int target) {
        if (low == high) {
            return low;
        }

        int mid = (low + high) / 2;
        if (bArr[mid] < target) {
            return lowerBound(mid + 1, high, target);
        } else {
            return lowerBound(low, mid, target);
        }
    } // End of lowerBound()

    private static void input() throws IOException {
        StringTokenizer st = new StringTokenizer(br.readLine());
        N = Integer.parseInt(st.nextToken());
        M = Integer.parseInt(st.nextToken());

        aArr = new int[N];
        bArr = new int[M];

        st = new StringTokenizer(br.readLine());
        for (int i = 0; i < N; i++) {
            aArr[i] = Integer.parseInt(st.nextToken());
        }

        st = new StringTokenizer(br.readLine());
        for (int i = 0; i < M; i++) {
            bArr[i] = Integer.parseInt(st.nextToken());
        }
        Arrays.sort(bArr);
    } // End of input()
} // End of Main class

0개의 댓글