結果
問題 | 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 sysimport 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 // D1else:D2 = 0print(D1, D2)