HDU 4355 Party All the Time(三分|二分)
2024-08-26 02:55:04
题意: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;
}
最新文章
- Android图片浏览器之图片删除
- J2EE相关总结
- Angular学习(5)- 数组双向梆定+filter
- Unieap3.5-需要用到window.setTimeout的地方
- SQL 存储过程 执行效率优化提升 (显示估计)
- linux下利用openssl来实现证书的颁发(详细步骤)--转载和修改
- 二叉树的实现 -- 数据结构与算法的javascript描述 第十章
- HDU 4836 The Query on the Tree lca || 欧拉序列 || 动态树
- Tomcat和Java Virtual Machine的性能调优总结
- 【centos6.5 hadoop2.7 _64位一键安装脚本】有问题加我Q直接问
- Windows【端口被占用,杀死想啥的端口】
- PHP——laravel之DB类->;查询
- Linux 平台 tcpdump 抓包
- Spring Data Solr入门
- Codeforces 995 E - Number Clicker
- CUDA Samples: 获取设备属性信息
- CS231n学习笔记-图像分类笔记(下篇)
- getpass模块
- VS2013新特性
- Linux命令(基础3)
热门文章
- 【bzoj3771】Triple FFT+容斥原理
- Python 安装MySQLdb模块遇到报错及解决方案:_mysql.c(42) : fatal error C1083: Cannot open include file: &#39;config-win.h&#39;: No such file or directory
- 【03】react 之 创建component
- HDOJ 2222: Keywords Search
- 【BZOJ4504&;&;Hihocoder1046】K个串(主席树,堆)
- git ssh 生成步骤
- js5:框架的使用,使框架之间无痕连接
- luogu 2463 [SDOI2008]Sandy的卡片 kmp || 后缀数组 n个串的最长公共子串
- fprintf与fscanf
- 使用Nginx+FFMPEG搭建HLS直播转码服务器