• 松江1843路


    题目描述

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

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

    公交站应该建在哪里呢?

    输入格式

    第一行输入L、N。

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

    输出格式

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

    输入输出样例

    输入 #1
    100 3
    20 3
    50 2
    70 1
    输出 #1
    110
    
    
    输入 #2
    100 2
    0 1
    100 10
    输出 #2
    100
    输入 #3
    10000000000 5
    3282894320 391
    4394338332 929
    6932893249 181
    7823822843 440
    9322388365 623
    输出 #3
    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

    额,小学经典数学题,但枚举肯定爆,所以用记搜吧。

    #include<cstdio>
    #include<algorithm>
    #include<cmath>
    using namespace std;
    long long x[100005];
    long long r[100005];
    int main()
    {
        long long n,m;
        scanf("%lld%lld",&n,&m);
        long long s=0;
        for(int i=0;i<m;i++){
            scanf("%lld%lld",&x[i],&r[i]);
            s+=r[i];
        }
        s/=2;
        long long s1=0;
        long long p=0;
        for(int i=0;i<m;i++){
            s1+=r[i];
            if(s1>s){
                p=x[i];
                break;
            }
            else if(s1==s){
                p=(x[i]+x[i+1])/2;
                break;
            }
        }
        long long ans=0;
        for(int i=0;i<m;i++){
            ans+=(abs(p-x[i])*r[i]);
        }
        printf("%lld",ans);
    }
  • 相关阅读:
    uva 10127
    POJ 3280 Cheapest Palindrome
    看图学英语
    看图学英语
    算法 Tricks(四)—— 获取一个数二进制形式第一个不为 0 的位置
    算法 Tricks(四)—— 获取一个数二进制形式第一个不为 0 的位置
    Opencv Surf算子中keyPoints,描述子Mat矩阵,配对向量DMatch里都包含了哪些好玩的东东?
    强大的 function adapters
    强大的 function adapters
    transform、accumulate —— C++ 下的 MapReduce
  • 原文地址:https://www.cnblogs.com/hrj1/p/11186258.html
Copyright © 2020-2023  润新知