
菜鸡目前只做了1AB..
1A 如果可以用x秒,显然小于x秒时也可使用。故考虑二分时间。
得到了时间,我们就可以算出p的贡献为p*t。
然后遍历每台机器,若cost[i]*t > stored[i], 说明这台机器需要分配资源。
所有机器分配完之后的总资源还大于等于0则说明可以运行到t。
需要注意的是,这题eps = -4, 二分上界为1e11才过= =..二分浮点还是老老实实for个百遍吧..
1B 考虑顶点i,若移动此点,则(i-1+n)%n, (i+1)%n也得动。
极限情况下这三点构成的三角形会退化成直线。
由于退化后这个三角形的周长其实是均摊到原图的,原图的周长不变,所以在纸上画一画发现其实就是原三角形把高一半处上方的三角形用高截成了两半,然后分到两边填充。
所以只需要算出这个高,答案就是所有高中最短的/2。
至于高的计算可以通过余弦定理算出cos,得到sin然后算出面积,除以底得到。
1A 如果可以用x秒,显然小于x秒时也可使用。故考虑二分时间。
得到了时间,我们就可以算出p的贡献为p*t。
然后遍历每台机器,若cost[i]*t > stored[i], 说明这台机器需要分配资源。
所有机器分配完之后的总资源还大于等于0则说明可以运行到t。
需要注意的是,这题eps = -4, 二分上界为1e11才过= =..二分浮点还是老老实实for个百遍吧..
1B 考虑顶点i,若移动此点,则(i-1+n)%n, (i+1)%n也得动。
极限情况下这三点构成的三角形会退化成直线。
由于退化后这个三角形的周长其实是均摊到原图的,原图的周长不变,所以在纸上画一画发现其实就是原三角形把高一半处上方的三角形用高截成了两半,然后分到两边填充。
所以只需要算出这个高,答案就是所有高中最短的/2。
至于高的计算可以通过余弦定理算出cos,得到sin然后算出面积,除以底得到。