HDU 4355 Party All the Time(三分|二分)

来源:互联网 发布:淘宝的muji官方旗舰店 编辑:程序博客网 时间:2024/06/07 23:38

题意:n个人,都要去参加活动,每个人都有所在位置xi和Wi,每个人没走S km,就会产生S^3*Wi的“不舒适度”,求在何位置举办活动才能使所有人的“不舒适度”之和最小,并求最小值。

思路:首先可以得出最后距离之和的表达式最多只有两个极点,

更进一步只有一个极点,否则无最小值。

那么我们就可用三分法或者二分法求解,即对原函数三分或对导数二分即可。

#include<cstdio>  #include<cstring>  #include<cmath>  #include<cstdlib>  #include<iostream>  #include<algorithm>  #include<vector>  #include<map>  #include<queue>  #include<stack> #include<string>#include<map> #include<set>#define eps 1e-6 #define LL long long  #define pii pair<int,int>using namespace std;  const int maxn = 100000+100;//const int INF = 0x3f3f3f3f;double w[maxn], x[maxn];int n;double fx(double x0) {double ans = 0;for(int i = 0; i < n; i++) {ans += pow(fabs(x[i]-x0), 3)*w[i];}return ans;}double find(double L, double R) {for(int i = 0; i < 30; i++) {double midl = L+(R-L)/3, midr = L+(R-L)*2/3;if(fx(midl) <= fx(midr)) R = midr;else L = midl;}return R;}int main() {//freopen("input.txt", "r", stdin);int T; cin >> T;int kase = 0;while(T--) {cin >> n;double minp = 1000000, maxp = -1000000;for(int i = 0; i < n; i++) {scanf("%lf%lf", &x[i], &w[i]);minp = min(minp, x[i]);maxp = max(maxp, x[i]);}//cout << fx(0) << endl;printf("Case #%d: %d\n", ++kase, (int)(fx(find(minp, maxp))+0.5));}return 0;}



0 0
原创粉丝点击