結果
| 問題 | 
                            No.306 さいたま2008
                             | 
                    
| コンテスト | |
| ユーザー | 
                             btk
                         | 
                    
| 提出日時 | 2015-11-27 23:52:37 | 
| 言語 | C++11(廃止可能性あり)  (gcc 13.3.0)  | 
                    
| 結果 | 
                             
                                WA
                                 
                             
                            
                         | 
                    
| 実行時間 | - | 
| コード長 | 644 bytes | 
| コンパイル時間 | 1,479 ms | 
| コンパイル使用メモリ | 159,580 KB | 
| 実行使用メモリ | 5,376 KB | 
| 最終ジャッジ日時 | 2024-09-14 01:31:37 | 
| 合計ジャッジ時間 | 2,270 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge4 / judge1 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 21 WA * 2 | 
ソースコード
#include <bits/stdc++.h>
using namespace std;
const double eps=1e-8;
double Xa,Xb,Ya,Yb;
inline double calc(double yy){
    double t=Yb-yy;
    double l=yy-Ya;
    return sqrt(Xb*Xb+t*t)+sqrt(Xa*Xa+l*l);
}
int main() {
    cout<<setprecision(8);
    cout<<fixed;
    cin>>Xa>>Ya>>Xb>>Yb;
    if(Ya>Yb){
        swap(Xa,Xb);
        swap(Ya,Yb);
    }
    {
        double top=Yb;
        double bottom=Ya;
        while(top-bottom>eps){
            double m1=(top*2+bottom)/3;
            double m2=(top+bottom*2)/3;
            if(calc(m1)<calc(m2))bottom=m2;
            else top=m1;
        }
        cout<<top<<endl;
    }
    return 0;
}
            
            
            
        
            
btk