結果
問題 |
No.356 円周上を回る3つの動点の一致
|
ユーザー |
|
提出日時 | 2016-04-02 00:19:22 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,057 bytes |
コンパイル時間 | 672 ms |
コンパイル使用メモリ | 60,868 KB |
実行使用メモリ | 10,276 KB |
最終ジャッジ日時 | 2024-10-02 09:11:14 |
合計ジャッジ時間 | 7,418 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | WA * 1 TLE * 1 -- * 46 |
ソースコード
#include <iostream> #include <cmath> bool isEqual(double a, double b){ return (std::fabs(a-b)<0.0001); } bool areEqual(double a, double b, double c){ return (isEqual(a, b) && isEqual(b, c) && isEqual(c, a)); } int main() { std::ios::sync_with_stdio(false); std::cin.tie(0); double time = 0; double t1, t2, t3; std::cin >> t1 >> t2 >> t3; while(true){ time += 1.0/6.0; double pos1x = std::cos(2*M_PI*time/t1); double pos2x = std::cos(2*M_PI*time/t2); double pos3x = std::cos(2*M_PI*time/t3); if(!areEqual(pos1x, pos2x, pos3x)) continue; double pos1y = std::sin(2*M_PI*time/t1); double pos2y = std::sin(2*M_PI*time/t2); double pos3y = std::sin(2*M_PI*time/t3); if(areEqual(pos1y, pos2y, pos3y)) break; } if(isEqual(time, std::round(time))){ std::cout << time << "/1\n"; }else if(isEqual(time*2, std::round(time*2))){ std::cout << time*2 << "/2\n"; }else{ std::cout << time*3 << "/3\n"; } return 0; }