結果
| 問題 |
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)