#include<bits/stdc++.h>
#define endl '\n'
#define INF 0x3f3f3f3f
#define ll long long
#define Mirai ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
using namespace std;
const int N=2e6+10,mod=998244353;
int n,m;
struct Node
{
double l,r,w;
}g[N];
bool check(double mid)
{
double res=0;
for(int i=0;i<n;i++)
{
if(mid>g[i].r)res+=1;
else if(mid<g[i].l)continue;
else res+=(mid-g[i].l)/g[i].w;
}
if(res>=m)return true;
else return false;
}
int main()
{
cin>>n>>m;
double li=INF,ri=0;//li和ri先确定最大二分空间
for(int i=0;i<n;i++)
{
cin>>g[i].l>>g[i].r;
g[i].w=g[i].r-g[i].l;
li=min(li,g[i].l);
ri=max(ri,g[i].r);
}
while(ri-li>1e-5)
{
double mid=(li+ri)/2;
if(check(mid))ri=mid;
else li=mid;
}
printf("%.10lf",li);
return 0;
}
leeing Sunlight
最新推荐文章于 2024-08-13 15:05:22 发布