输入描述
第一行两个正整数 ll 和 rr (1\leqslant l 1⩽l<r⩽2000)。
第二行两个正整数 LL 和 RR (1\leqslant L 1⩽L<R⩽2000)。
输出描述
一个实数,表示最大的期望利润。(四舍五入后保留 44 位小数,输出超过 44 位或少于 44位都会获得 Wrong Answer。)
如果答案为 00,请不要输出多余的负号。
若答案为 vv,保证 v+10^{-6}v+10−6 以及 max(v-10^{-6},0)max(v−10−6,0) 四舍五入后保留 44 位小数的结果不会改变。
样例输出 2
0.0000
思路:
因为主人公的售价是 L~R 所以 主人公售价的期望是 (L+R)/2
我们给买手的钱是p,那么我们主人公的利润就是 ((L+R)/2-p)
我们知道 期望=值*概率
利润期望=利润值*概率
我们来看下概率,
P必须取到 l和r之间,因为如果p大于r,那么不是最优的选择,因为可以选择r可以产生更好的利益。
而p小于l的话,买手会无法购物商品,所以也不可以。
那么p就在 l和r之间了,
买手能买商品的时候当且仅当 商品的市场价 恰好小于等于p,也就是市场价y小于p时,可以购买,
那么y的范围时 l~p,总范围是l~r,所以概率是 (p-l)/(r-l)
期望就是
((L+R)/2-p)*(p-l)/(r-l)
公式就是一个关于p的二次函数,并且a是小于等于0的,有极大值,我们判定对称轴是否在l到r之间,
如果在,那么函数的极值就是答案,如果不在,那么取区间的左右极限的较大值是答案。
注意处理以下0*负数=-0的情况,
细节见code
#include
#include
#include
#include
#include
#include
#include
#include