zoukankan      html  css  js  c++  java
  • C

    Time limit : 2sec / Memory limit : 256MB

    Score : 500 points

    Problem Statement

    On an xy plane, in an area satisfying 0≤xW,0≤yH, there is one house at each and every point where both x and y are integers.

    There are unpaved roads between every pair of points for which either the x coordinates are equal and the difference between the y coordinates is 1, or the ycoordinates are equal and the difference between the x coordinates is 1.

    The cost of paving a road between houses on coordinates (i,j) and (i+1,j) is pi for any value of j, while the cost of paving a road between houses on coordinates(i,j) and (i,j+1) is qj for any value of i.

    Mr. Takahashi wants to pave some of these roads and be able to travel between any two houses on paved roads only. Find the solution with the minimum total cost.

    Constraints

    • 1≦W,H≦105
    • 1≦pi≦108(0≦iW−1)
    • 1≦qj≦108(0≦jH−1)
    • pi(0≦iW−1) is an integer.
    • qj(0≦jH−1) is an integer.

    Input

    Inputs are provided from Standard Input in the following form.

    W H
    p0
    :
    pW−1
    q0
    :
    qH−1
    

    Output

    Output an integer representing the minimum total cost.


    Sample Input 1

    Copy
    2 2
    3
    5
    2
    7
    

    Sample Output 1

    Copy
    29
    

    It is enough to pave the following eight roads.

    • Road connecting houses at (0,0) and (0,1)
    • Road connecting houses at (0,1) and (1,1)
    • Road connecting houses at (0,2) and (1,2)
    • Road connecting houses at (1,0) and (1,1)
    • Road connecting houses at (1,0) and (2,0)
    • Road connecting houses at (1,1) and (1,2)
    • Road connecting houses at (1,2) and (2,2)
    • Road connecting houses at (2,0) and (2,1)

    Sample Input 2

    Copy
    4 3
    2
    4
    8
    1
    2
    9
    3
    

    Sample Output 2

    Copy
    60

    类似于克鲁斯卡尔算法求最小生成树。只不过题目中给的点到点的值和往常不同。

    /* ***********************************************
    Author        :guanjun
    Created Time  :2016/10/11 14:54:59
    File Name     :1.cpp
    ************************************************ */
    #include <bits/stdc++.h>
    #define ull unsigned long long
    #define ll long long
    #define mod 90001
    #define INF 0x3f3f3f3f
    #define maxn 10010
    #define cle(a) memset(a,0,sizeof(a))
    const ull inf = 1LL << 61;
    const double eps=1e-5;
    using namespace std;
    priority_queue<int,vector<int>,greater<int> >pq;
    struct Node{
        int x,y;
    };
    struct cmp{
        bool operator()(Node a,Node b){
            if(a.x==b.x) return a.y> b.y;
            return a.x>b.x;
        }
    };
    
    bool cmp(int a,int b){
        return a>b;
    }
    typedef pair<ll,int> pii;
    vector<pii>v;
    int main()
    {
        #ifndef ONLINE_JUDGE
        //freopen("in.txt","r",stdin);
        #endif
        //freopen("out.txt","w",stdout);
        ll h,w,x;
        while(scanf("%lld %lld",&w,&h)!=EOF){
            v.clear();
            for(int i=0;i<w;i++){
                scanf("%lld",&x);
                v.push_back({x,0});
            }
            for(int i=0;i<h;i++){
                scanf("%lld",&x);
                v.push_back({x,1});
            }
            sort(v.begin(),v.end());
            ll ans=0;
            w++;
            h++;
            for(int i=0;i<v.size();i++){
                if(v[i].second==1){
                    ans+=w*v[i].first;
                    h--;
                }
                else {
                    ans+=h*v[i].first;
                    w--;
                }
            }
            printf("%lld
    ",ans);
        }
        return 0;
    }
  • 相关阅读:
    开源 Serverless 里程碑:Knative 1.0 来了
    以一致的体验交付和管理云原生多集群应用
    iLogtail使用入门K8S环境日志采集到SLS
    如何在golang代码里面解析容器镜像
    mac vmware 无法复制粘贴
    使用vi编辑时上下左右方向键被转化为A、B、C、D
    left join 和 left outer join 的区别
    设计模式之 适配器模式
    设计模式之 命令模式
    设计模式学习之 策略模式
  • 原文地址:https://www.cnblogs.com/pk28/p/5960637.html
Copyright © 2011-2022 走看看