前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >P3819 松江1843路

P3819 松江1843路

作者头像
attack
发布2018-04-12 15:33:53
6450
发布2018-04-12 15:33:53
举报

题目描述

涞坊路是一条长L米的道路,道路上的坐标范围从0到L,路上有N座房子,第i座房子建在坐标为x[i]的地方,其中住了r[i]人。

松江1843路公交车要在这条路上建一个公交站,市政府希望让最多的人得到方便,因此希望所有的每一个的居民,从家到车站的距离的总和最短。

公交站应该建在哪里呢?

输入输出格式

输入格式:

第一行输入L、N。

接下来N行,每行两个整数x[i]和r[i]

输出格式:

一个整数,最小的每个人从家到车站的距离的总和。

输入输出样例

输入样例#1:

代码语言:javascript
复制
100 3
20 3
50 2
70 1

输出样例#1:

代码语言:javascript
复制
110

输入样例#2:

代码语言:javascript
复制
100 2
0 1
100 10

输出样例#2:

代码语言:javascript
复制
100

输入样例#3:

代码语言:javascript
复制
10000000000 5
3282894320 391
4394338332 929
6932893249 181
7823822843 440
9322388365 623

输出样例#3:

代码语言:javascript
复制
5473201404068

说明

样例解释1

当建在坐标40的时候,所有人距离车站的距离总和为 |20−40|×3+|50−40|×2+|70−40|×1=110。

数据范围和约定

对于10%的数据,1≤N≤50,R[i]=1。

对于30%的数据,1≤N≤100,R[i]≤10,1≤L≤1000。

对于70%的数据,1≤N≤1000,R[i]≤100,1≤L≤10^6

对于全部数据,1≤L≤10^10,1≤N≤10^5,0≤x[i]≤L,1≤r[i]≤1000

我们可以证明出:

1.最小的点一定是建在某个房子上。,

2.这个房子是重点!

代码语言:javascript
复制
 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<cmath>
 5 #include<queue>
 6 #include<algorithm>
 7 #define lli long long int 
 8 using namespace std;
 9 const int MAXN=100001;
10 void read(lli  &n)
11 {
12     char c='+';lli x=0;bool flag=0;
13     while(c<'0'||c>'9')
14     {c=getchar();if(c=='-')flag=1;}
15     while(c>='0'&&c<='9')
16     {x=x*10+(c-48);c=getchar();}
17     flag==1?n=-x:n=x;
18 }
19 lli l,n;
20 struct node
21 {
22     lli x,pep;
23 }a[MAXN];
24 lli tot;
25 lli comp(const node &a,const node &b)
26 {
27     return a.x<b.x;
28 }
29 int main()
30 {
31     read(l);read(n);
32     for(lli i=1;i<=n;i++)
33     {
34         read(a[i].x);read(a[i].pep);
35         tot+=a[i].pep;
36     }
37     tot=(tot+1)/2;
38     
39     sort(a+1,a+n+1,comp);
40     
41     lli now=0;
42     lli mid=0;
43     for(lli i=1;i<=n;i++)
44     {
45         now+=a[i].pep;
46         if(now>=tot)
47         {
48             mid=i;
49             break;
50         }
51     }
52     lli ans=0;
53     for(lli i=1;i<=n;i++)
54     {
55         ans+=(a[i].pep*abs(a[mid].x-a[i].x));
56     }
57     printf("%lld",ans);
58     return 0;
59 }
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-07-02 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目描述
  • 输入输出格式
  • 输入输出样例
  • 说明
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档