Submission #1132318

#TimeUsernameProblemLanguageResultExecution timeMemory
1132318Adeeb_obedoMobile (BOI12_mobile)C++17
50 / 100
1098 ms70896 KiB
#include <bits/stdc++.h> #define int long long #define _1 first #define _2 second #define yes cout<<"Yes\n" #define nah cout<<"No\n" #define FFF ios_base::sync_with_stdio(0);cin.tie(0); #define ipr pair<int,int> #define ret return #define intt int32_t #define mid ((l+r)/2) #define pb push_back #define ll long long #define ld double #define lll __int128_t using namespace std; int tst, ts; const intt mo = 1e9 + 7, dx[] = {-1, 1, 0, 0}, dy[] = {0, 0, -1, 1}; int mul( int x, int y ) { ret ( ( x % mo ) * ( y % mo ) ) % mo; ret x*y; } int pwo( int x, int y ) { int res = 1; for( int i = 63; i + 1; i-- ) res = mul( res, res * ( ( 1ll << i )&y ? x : 1 ) ); ret res; } int dvii( int x, int y ) { ret mul( x, pwo( y, mo - 2 ) ); } int oo( char x ) { ret ( int )x - '0'; } int lgg( int x, int y ) { int u = 0; while( x ) { u++; x /= y; } ret u; } int mun( int x, int y ) { while( x < y )x += mo; ret ( x - y ) % mo; } int add( int x, int y ) { ret x + y - ( mo * ( x + y >= mo ) ); ret x + y; } int lcm( int x, int y ) { ret ( x * y ) / __gcd( x, y ); } #define endl '\n' const int M = 2007, N = 1e6 + 7, N2 = 5e3 + 7, inf = 3e9+7; int n,L; pair<intt,intt>a[N]; pair<ld,ld>b[N]; ld fs(ld x){ ld l=-1.001,r=x+0.001; while(r-l>0.001){ ld p=mid; if(p*p>=x) r=p; else l=p; } ret r; } ld get(ld x,ld y){ ld p=(y*y)/(x*x); ld on=1; p=on-p; p=sqrt(p); p*=x; //cout<<x<<" "<<y<<" "<<p<<endl; ret p; } bool is(ld x){ int k=0; map<ld,ld>mp; for(int i=0;i<n;i++){ ld p=get(x,a[i]._2); if(a[i]._1+p>=0) mp[a[i]._1-p]=max(a[i]._1-p,a[i]._1+p); } ld o=0; for(auto it:mp){ if(it._1>o) break; o=max(o,it._2); } ret (o>=L); } void solve() { cin>>n>>L; for(int i=0;i<n;i++) cin>>a[i]._1>>a[i]._2; for(int i=0;i<n;i++) a[i]._2=abs(a[i]._2); ld l=0.0,r=inf+0.1; for(int i=0;i<100;i++){ if(r-l<=0.001) break; ld p=mid; if(is(p)) r=p; else l=p; } cout<<fixed<<setprecision(3)<<(ld)r<<endl; } intt main() { FFF/* freopen("convention2.in", "r", stdin); freopen("convention2.out", "w", stdout);/* for( int i = 2; i < N; i++ ) { if( sv[i] == 0 ) { for( int j = i + i; j < N; j += i ) sv[j] = 1; } } ff[0] = 1; for( int i = 1; i < N; i++ ) ff[i] = mul( ff[i - 1], i ); */ tst = 1; //cin >> tst; for( ts = 1; ts <= tst; ts++ ) { solve(); } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...