結果

問題 No.1236 長針と短針
ユーザー Theta
提出日時 2022-11-02 17:01:53
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
AC  
実行時間 33 ms / 2,000 ms
コード長 1,071 bytes
コンパイル時間 201 ms
コンパイル使用メモリ 12,544 KB
実行使用メモリ 10,880 KB
最終ジャッジ日時 2024-07-17 06:11:38
合計ジャッジ時間 1,925 ms
ジャッジサーバーID
(参考情報)
judge5 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 20
権限があれば一括ダウンロードができます

ソースコード

diff #

from math import floor


def calc_short_degree(hour, minute, second) -> int:
    return (hour * 30) % 360 + minute/2 + second/120


def calc_long_degree(minute, second) -> int:
    return minute * 6 + second / 10


def main():
    until_zero_minute_time = 0
    A, B = map(int, input().split())
    long_degree = calc_long_degree(B, 0)
    short_degree = calc_short_degree(A, B, 0)
    if long_degree == short_degree:
        print(0)
        return

    if long_degree > short_degree:
        until_zero_minute_time = (60 - B) * 60
        long_degree = 0
        short_degree = (A+1, 0, 0)
        B = 0
        A += 1

    for time in range(1, 3601):
        long_degree = calc_long_degree(B + time // 60, time % 60)
        short_degree = calc_short_degree(A, B + time // 60, time % 60)
        if long_degree > short_degree:
            print(until_zero_minute_time + time - 1)
            return
        if long_degree == short_degree:
            print(until_zero_minute_time + time)
            return
    raise ValueError


if __name__ == "__main__":
    main()
0