POJ 1064 Cable master——二分 + 精度控制

网友投稿 580 2022-11-29

POJ 1064 Cable master——二分 + 精度控制

POJ 1064 Cable master——二分 + 精度控制

白书上的原题,对浮点数进行二分,注意保留两位小数不是四舍五入,2.579应该保留2.57

感觉这题没什么意思,为坑而坑,交G++错了,交C++就对了,貌似和scanf的判定有关

#include #include #include #include #include using namespace std;const int maxn = 100000 + 10;int N, K;double L[maxn];bool C(double x) { int num = 0; for (int i = 0; i < N; i++) { num += (int)(L[i] / x); } return num >= K;}void solve() { double lb = 0, ub = maxn; for (int i = 0; i < 100; i++) { double mid = (lb + ub) / 2; if (C(mid)) lb = mid; else ub = mid; } printf("%.2lf\n", floor(ub * 100) / 100);}int main(){ scanf("%d %d", &N, &K); for (int i = 0; i < N; i++) scanf("%lf", &L[i]); solve(); return 0;}

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:UVa 11729 Commando War——贪心
下一篇:POJ 2115 C Looooops——拓展欧几里得算法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~