题意: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;
}


最新文章

  1. Android图片浏览器之图片删除
  2. J2EE相关总结
  3. Angular学习(5)- 数组双向梆定+filter
  4. Unieap3.5-需要用到window.setTimeout的地方
  5. SQL 存储过程 执行效率优化提升 (显示估计)
  6. linux下利用openssl来实现证书的颁发(详细步骤)--转载和修改
  7. 二叉树的实现 -- 数据结构与算法的javascript描述 第十章
  8. HDU 4836 The Query on the Tree lca || 欧拉序列 || 动态树
  9. Tomcat和Java Virtual Machine的性能调优总结
  10. 【centos6.5 hadoop2.7 _64位一键安装脚本】有问题加我Q直接问
  11. Windows【端口被占用,杀死想啥的端口】
  12. PHP——laravel之DB类-&gt;查询
  13. Linux 平台 tcpdump 抓包
  14. Spring Data Solr入门
  15. Codeforces 995 E - Number Clicker
  16. CUDA Samples: 获取设备属性信息
  17. CS231n学习笔记-图像分类笔记(下篇)
  18. getpass模块
  19. VS2013新特性
  20. Linux命令(基础3)

热门文章

  1. 【bzoj3771】Triple FFT+容斥原理
  2. Python 安装MySQLdb模块遇到报错及解决方案:_mysql.c(42) : fatal error C1083: Cannot open include file: &#39;config-win.h&#39;: No such file or directory
  3. 【03】react 之 创建component
  4. HDOJ 2222: Keywords Search
  5. 【BZOJ4504&amp;&amp;Hihocoder1046】K个串(主席树,堆)
  6. git ssh 生成步骤
  7. js5:框架的使用,使框架之间无痕连接
  8. luogu 2463 [SDOI2008]Sandy的卡片 kmp || 后缀数组 n个串的最长公共子串
  9. fprintf与fscanf
  10. 使用Nginx+FFMPEG搭建HLS直播转码服务器