码迷,mamicode.com
首页 > 编程语言 > 详细

最小成本排序 挑战程序设计

时间:2017-07-19 23:31:31      阅读:246      评论:0      收藏:0      [点我收藏+]

标签:line   lan   max   clu   http   ons   for   end   main   

http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=ALDS1_6_D&lang=jp

最小成本排序:

#include <bits/stdc++.h>
using namespace std;
static const int maxn = 1000;
static const int vmax = 10000;
int n,A[maxn],s;
int B[maxn],T[vmax+1];
int solve()
{
    int ans=0;
    bool V[maxn];
    for(int i=0;i<n;i++){
        B[i]=A[i];
        V[i]=false;
    }
    sort(B,B+n);
    for(int i=0;i<n;i++)
    {
        T[B[i]]=i;
    }
    for(int i=0;i<n;i++)
    {
        if(V[i]) continue;
        int cur=i;
        int S=0;
        int m=vmax;
        int an=0;
        while(1)
        {
            V[cur]=true;
            an++;
            int v=A[cur];
            m=min(m,v);
            S+=v;
            cur=T[v];
            if(V[cur]) break;
        }
        ans+=min(S+(an-2)*m,m+S+(an+1)*m);
    }
    return ans;
}
int main()
{
    cin>>n;
    s=vmax;
    for(int i=0;i<n;i++)
    {
        cin>>A[i];
        s=min(s,A[i]);
    }
    int ans=solve();
    cout<<ans<<endl;
    return 0;
}

  

最小成本排序 挑战程序设计

标签:line   lan   max   clu   http   ons   for   end   main   

原文地址:http://www.cnblogs.com/masterchd/p/7208481.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!