結果
問題 | No.3020 ユークリッドの互除法・改 |
ユーザー |
|
提出日時 | 2025-02-14 21:26:30 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 32 ms / 2,000 ms |
コード長 | 477 bytes |
コンパイル時間 | 266 ms |
コンパイル使用メモリ | 12,288 KB |
実行使用メモリ | 10,368 KB |
最終ジャッジ日時 | 2025-02-14 21:26:51 |
合計ジャッジ時間 | 1,909 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 21 |
ソースコード
import sys import math # 入力の読み込み(行ごとに2個ずつの場合を想定) data = sys.stdin.read().strip().split() if not data: sys.exit(0) # 入力された文字列を整数に変換 A11, A12, A21, A22 = map(int, data) # 最大公約数の計算 g = math.gcd(math.gcd(A11, A12), math.gcd(A21, A22)) D1 = abs(g) # 非負にする # 行列式の絶対値 det = abs(A11 * A22 - A12 * A21) if D1 != 0: D2 = det // D1 else: D2 = 0 print(D1, D2)