1110 距离之和最小 V3
第1行:点的数量N。(2 <= N <= 10000)
第2 - N + 1行:每行2个数,中间用空格分隔,分别是点的位置及权值。(-10^5 <= X[i] <= 10^5,1 <= W[i] <= 10^5)
输出最小的带权距离之和。
5
-1 1
-3 1
0 1
7 1
9 1
20
思路:中位数。
将点的权值看成多个点就行。然后求中位数。
1 #include<stdio.h>
2 #include<algorithm>
3 #include<iostream>
4 #include<math.h>
5 using namespace std;
6 typedef struct node
7 {
8 int x;
9 int cost ;
10 } ss;
11 ss id[20000];
12 bool cmp(node p,node q)
13 {
14 return p.x<q.x;
15 }
16 typedef long long LL;
17 int main(void)
18 {
19 int n,i,j;
20 scanf("%d",&n);
21 LL sum = 0;
22 for(i = 0; i < n; i++)
23 {
24 scanf("%d %d",&id[i].x,&id[i].cost);
25 sum += id[i].cost;
26 }
27 LL mid = (sum+1)/2;
28 sort(id,id+n,cmp);
29 LL ak = 0;
30 for(i = 0; i < n; i++)
31 {
32 ak+=id[i].cost;
33 if(ak >= mid)
34 {
35 break;
36 }
37 }
38 int x =id[i].x;sum = 0;
39 for(i = 0;i < n;i ++)
40 {
41 sum += (LL)abs(id[i].x-x)*id[i].cost;
42 }
43 printf("%lld\n",sum);
44 return 0;
45 }
1110 距离之和最小 V3的更多相关文章
- 51 Nod 1110距离之和最小V3
		
1110 距离之和最小 V3 1 秒 131,072 KB 40 分 4 级题 X轴上有N个点,每个点除了包括一个位置数据X[i],还包括一个权值W[i].点P到点P[i]的带权距离 = 实际距离 * ...
 - 51Nod 1110 距离之和最小 V3 中位数 思维
		
基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 X轴上有N个点,每个点除了包括一个位置数据X[i],还包括一个权值W[i].点P到点P[i]的带权距离 = 实际距离 ...
 - 51nod 1110 距离之和最小V3
		
X轴上有N个点,每个点除了包括一个位置数据X[i],还包括一个权值W[i].点P到点P[i]的带权距离 = 实际距离 * P[i]的权值.求X轴上一点使它到这N个点的带权距离之和最小,输出这个最小的带 ...
 - 51nod1110 距离之和最小 V3
		
基准时间限制:1 秒 空间限制:131072 KB 分值: 40 X轴上有N个点,每个点除了包括一个位置数据X[i],还包括一个权值W[i].该点到其他点的带权距离 = 实际距离 * 权值.求X轴上 ...
 - Hdu4311 || 4312Meeting point-1/-2   n个点中任意选一个点使得其余点到该点曼哈顿距离之和最小
		
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission( ...
 - 某个点到其他点的曼哈顿距离之和最小(HDU4311)
		
Meeting point-1 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
 - 51Nod 1108 距离之和最小 V2 1096 距离之和最小  中位数性质
		
1108 距离之和最小 V2基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 收藏 关注三维空间上有N个点, 求一个点使它到这N个点的曼哈顿距离之和最小,输出这个最小 ...
 - 【51NOD】1096 距离之和最小
		
[算法]数学 [题解] 其实就是求中位数,奇数个点就是最中间的点,偶数个点就是最中间两个点和它们之间的区域皆可(所以偶数不必取到两点正中央,取两点任意一点即可). 我们可以想象现在x轴上有n个点,我们 ...
 - 51nod 1096 距离之和最小【中位数】
		
1096 距离之和最小 基准时间限制:1 秒 空间限制:131072 KB 分值: 20 难度:3级算法题 收藏 关注 X轴上有N个点,求X轴上一点使它到这N个点的距离之和最小,输出这个最小的距离 ...
 
随机推荐
- 27-Roman to Integer-Leetcode
			
Given a roman numeral, convert it to an integer. Input is guaranteed to be within the range from 1 t ...
 - SIG -MESH -1
			
协议栈 node:成为蓝牙mesh网络中一员的设备被称为节点(Node). 蓝牙mesh规格定义了节点可能拥有的特性.具有这些特性中的一个或多个,即表示节点可以在网络中扮演相应的特殊角色.定义的 ...
 - 设置administrator账号密码
			
设置administrator账号密码: 打开:附件->运行 输入:lusrmgr.msc 在里面的用户里修改administrator密码
 - javaSE高级篇1 — 异常与多线程基础
			
1.异常的体系结构 注:Throwable是一个类,不是一个接口,这个类里面是描述的一些Error和Exception的共性,如图所示: 异常 / 错误是什么意思? 定义:指的是程序运行过程中,可能 ...
 - SimpleNVR如何把安防监控画面推流到微信公众号直播
			
背景需求 进入移动互联网时代以来,微信已成为许多企业除官网以外必备的宣传渠道,当3.2亿直播用户与九亿微信用户的势能增加,在微信上开启直播已成为越来越多企业的不二选择. 需求分析 微信公众号作为平台来 ...
 - idea安装插件 JClassLib Bytecode viewer
			
目录 idea安装插件 JClassLib Bytecode viewer 安装过程 使用 idea安装插件 JClassLib Bytecode viewer IDEA 中安装 jClassLib ...
 - Java8 Lambda表达式、函数式接口和方法引用
			
目录 Java8 Lambda表达式和函数式接口 Lambda表达式 Lambda的使用 函数式接口FunctionalInterface Java内置四大核心函数式接口 方法引用 构造器引用 Jav ...
 - Flink(二)【架构原理,组件,提交流程】
			
目录 一.运行架构 1.架构 2.组件 二.核心概念 TaskManager . Slots Parallelism(并行度) Task .Subtask Operator Chains(任务链) E ...
 - 【leetcode】653. Two Sum IV - Input is a BST
			
Given the root of a Binary Search Tree and a target number k, return true if there exist two element ...
 - Fragment放置后台很久(Home键退出很长时间),返回时出现Fragment重叠解决方案
			
后来在google查到相关资料,原因是:当Fragment长久不使用,系统进行回收,FragmentActivity调用onSaveInstanceState保存Fragment对象.很长时间后,再次 ...