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;
    }
  • 相关阅读:
    在安装ODAC后再安装.netframework导致应用程序无法找到.netframework data provider的解决方案(3种)
    浅谈Scrum敏捷开发:4个输入/输出、3个关键物、3个会议
    Payoneer个人账户注册申请教程
    巧用netsh命令实现端口转发(端口映射)不求人
    京东也开始欺骗消费者了
    powershell解决win10开始菜单和通知中心无法打开
    有些其他程序设置为从 Outlook 下载并删除邮件。为防止发生此意外情况,我们将这些邮件放入一个特殊的 POP 文件夹中
    maven搭建
    java面试第四弹(算法和编程)思路
    每秒处理10万高并发订单的乐视集团支付系统架构分享
  • 原文地址:https://www.cnblogs.com/pk28/p/5960637.html
Copyright © 2011-2022 走看看