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