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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了最小成本排序 挑战程序设计相关的知识,希望对你有一定的参考价值。

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;
}

  

以上是关于最小成本排序 挑战程序设计的主要内容,如果未能解决你的问题,请参考以下文章

如何从任务池中排序任务以最小化时间成本?

从搜索文档中查找最小片段的算法?

解决方案电影标题中缺少代码的片段,完成挑战更多[关闭]

POJ 3262 Protecting the Flowers 题解 《挑战程序设计竞赛》

2017华为软件挑战赛总结

挑战程序设计竞赛(算法和数据结构)——7.1归并排序JAVA实现