結果
問題 |
No.442 和と積
|
ユーザー |
|
提出日時 | 2018-06-06 17:03:10 |
言語 | C (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 1 ms / 1,000 ms |
コード長 | 608 bytes |
コンパイル時間 | 232 ms |
コンパイル使用メモリ | 29,184 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-07-04 23:12:47 |
合計ジャッジ時間 | 1,009 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 18 |
ソースコード
#include<stdio.h> long long int gcd(long long int C, long long int D) { long long int div1, r, tmp1, tmp2; div1 = D; r = C % D; while ((r != 0)&&(r != 1)) { tmp1 = div1; tmp2 = r; div1 = r; r = tmp1 % tmp2; } if (r == 1) return 1; else return div1; } int main(void) { long long int A, B; long long int g, ans; scanf("%lld", &A); scanf("%lld", &B); if(A>B) g = gcd(A, B); else g = gcd(B, A); if (g != 1) { long long int tmp = (A + B) / g; if (tmp > g) ans = g * gcd(tmp, g); else ans = g * gcd(g, tmp); } else ans = 1; printf("%lld\n", ans); return 0; }