본문 바로가기
Coding Test/Java Coding Test

[백준알고리즘 / 자바] - 윤년

by nam_ji 2024. 11. 14.

윤년 - 브론즈 5

문제


테스트 (인텔리제이)

import java.util.GregorianCalendar;
import java.util.Scanner;

public class 윤년 {
    public static void main(String[] args) {
        /*
        문제
        연도가 주어졌을 때, 윤년이면 1, 아니면 0을 출력문제입니다.
        윤년은 연도가 4의 배수이면서, 100의 배수가 아닐 때 또는 400의 배수일 때이다.
        예를 들어, 2012년은 4의 배수이면서 100의 배수가 아니라서 윤년이다.
        1900년은 100의 배수이고 400의 배수는 아니기 때문에 윤년이 아니다.
        하지만, 2000년은 400의 배수이기 때문에 윤년이다.

        입력
        첫째 줄에 연도가 주어진다. 연도는 1보다 크거나 같고, 4000보다 작거나 같은 자연수이다.

        출력
        첫째 줄에 윤년이면 1, 아니면 0을 출력한다.

        입출력 예시
        입력     출력
        2000    1
        1999    0
         */
        Scanner in = new Scanner(System.in);
        int i = in.nextInt();

        solution1(i);
        solution2(i);
    }

    public static void solution1(int i) {
        GregorianCalendar gregorianCalendar = new GregorianCalendar();
        if (gregorianCalendar.isLeapYear(i)) {
            System.out.println(1);
        } else {
            System.out.println(0);
        }
    }

    public static void solution2(int i) {
        if ((i % 4 == 0 && i % 100 != 0) || i % 400 == 0) {
            System.out.println(1);
        } else {
            System.out.println(0);
        }
    }
}

백준알고리즘 코드

public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int i = in.nextInt();

        solution1(i);
    }
    
    public static void solution1(int i) {
        if ((i % 4 == 0 && i % 100 != 0) || i % 400 == 0) {
            System.out.println(1);
        } else {
            System.out.println(0);
        }
    }
}