백준 24313번 : 점근적 표기 1

박찬규·2023년 3월 26일
0

91%에서 자꾸 틀리길래 반례를 찾아봤다.
7n - 2 <= 6n 일때 답이 틀렸고,

if (a1 - c != 0) {
            int k = -a0 / (a1 - c);
            if (n < k) {
                answer = 0;
            }
        }

위 코드를 추가했다. 간단한 문제였는데 시간을 너무 많이 잡아먹었다.

import java.io.*;
import java.util.*;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringTokenizer st = new StringTokenizer(br.readLine());

        int a1 = Integer.parseInt(st.nextToken());
        int a0 = Integer.parseInt(st.nextToken());
        int c = Integer.parseInt(br.readLine());
        int n0 = Integer.parseInt(br.readLine());
        int n = n0;
        int answer = 1;

        int fn = a1 * n + a0;
        int gn = c * n;

        if (a1 - c != 0) {
            int k = -a0 / (a1 - c);
            if (n < k) {
                answer = 0;
            }
        }
        
        if (fn > gn) {
            answer = 0;
        }

        System.out.println(answer);
    }
}

0개의 댓글