結果
問題 |
No.3020 ユークリッドの互除法・改
|
ユーザー |
![]() |
提出日時 | 2025-02-14 22:49:44 |
言語 | C (gcc 13.3.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,482 bytes |
コンパイル時間 | 201 ms |
コンパイル使用メモリ | 26,112 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2025-02-14 22:49:46 |
合計ジャッジ時間 | 1,131 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge6 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 18 WA * 3 |
コンパイルメッセージ
main.c: In function ‘main’: main.c:8:25: warning: ignoring return value of ‘scanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 8 | scanf("%lld", &a[i][j]); | ^~~~~~~~~~~~~~~~~~~~~~~
ソースコード
#include<stdio.h> int main() { long long int a[2][2]; long long int i, j, d; for (i = 0; i < 2; i++) for (j = 0; j < 2; j++) scanf("%lld", &a[i][j]); for (i = 0; i < 4; i++) { if (a[0][0] < 0) { a[0][0] *= -1; a[1][0] *= -1; } if (a[0][0] > 0) { if (a[0][1] < 0) { a[0][1] *= -1; a[1][1] *= -1; } if (a[0][1] == 0) { a[0][1] += a[0][0]; a[1][1] += a[1][0]; } for (; a[0][0] > 0;) { if (a[0][1] % a[0][0] == 0) { d = a[0][1] / a[0][0]; d--; a[0][1] -= a[0][0] * d; a[1][1] -= a[1][0] * d; a[0][0] -= a[0][1]; a[1][0] -= a[1][1]; } else if (a[0][0] > a[0][1]) { d = a[0][0] / a[0][1]; a[0][0] -= d * a[0][1]; a[1][0] -= d * a[1][1]; } else { d = a[0][1] / a[0][0]; a[0][1] -= d * a[0][0]; a[1][1] -= d * a[1][0]; } } } d = a[0][0]; a[0][0] = a[0][1]; a[0][1] = a[1][1]; a[1][1] = a[1][0]; a[1][0] = d; } if (a[0][0] < 0) { a[0][0] *= -1; a[0][1] *= -1; } if (a[0][1] < 0) { a[0][1] *= -1; a[1][1] *= -1; } if (a[1][0] < 0) { a[1][0] *= -1; a[1][1] *= -1; } if (a[0][0] > 0) { d = a[0][1] / a[0][0]; a[0][1] -= d * a[0][0]; a[1][1] -= d * a[1][0]; d = a[1][0] / a[0][0]; a[1][0] -= d * a[0][0]; a[1][1] -= d * a[0][1]; } if (a[1][1] < 0) a[1][1] *= -1; if (a[1][1] == 0) { a[1][1] = a[0][0]; a[0][0] = 0; } printf("%lld %lld\n", a[0][0], a[1][1]); return 0; }