• codevs 1028 花店橱窗布置


    时间限制: 1 s
     空间限制: 128000 KB
     题目等级 : 钻石 Diamond
    题目描述 Description

    假设以最美观的方式布置花店的橱窗,有F束花,V个花瓶,我们用美学值(一个整数)表示每束花放入每个花瓶所产生的美学效果。为了取得最佳的美学效果,必须使花的摆放取得最大的美学值。

    输入描述 Input Description

    第一行为两个整数F,V(F<=V<=100)

    接下来F行每行V个整数,第i行第j个数表示第i束花放入第j个花瓶的美学值。

    输出描述 Output Description

    一个整数,即最大美学值。

    样例输入 Sample Input

    2 2

    10 0

    5 2

    样例输出 Sample Output

    12

    数据范围及提示 Data Size & Hint

     

    二分图

    km或费用流

    本蒟蒻用的费用流 机房某z姓大佬好像在学km 先模几发%%%

    屠龙宝刀点击就送

    #include <cstdio>
    #include <queue>
    #define N 1000005
    #define FWQ 0xefefefef
    using namespace std;
    struct Edge
    {
        int next,flow,cost,to;
    }edge[N<<1];
    bool vis[N];
    int head[N],cnt=1,F,V,fa[N],dis[N];
    void ins(int u,int v,int w,int l)
    {
        edge[++cnt].next=head[u];
        edge[cnt].to=v;
        edge[cnt].flow=w;
        edge[cnt].cost=l;
        head[u]=cnt;
    }
    bool spfa(int s,int t)
    {
        queue<int>q;
        for(int i=s;i<=t;++i) vis[i]=0,dis[i]=FWQ;
        dis[s]=0;
        q.push(s);
        for(int now;!q.empty();)
        {
            now=q.front();
            q.pop();
            vis[now]=0;
            for(int u=head[now];u;u=edge[u].next)
            {
                int v=edge[u].to;
                if(dis[v]<dis[now]+edge[u].cost&&edge[u].flow)
                {
                    dis[v]=dis[now]+edge[u].cost;
                    fa[v]=u;
                    if(!vis[v])
                    {
                        vis[v]=1;
                        q.push(v); 
                    }
                }
            }
        }
        return dis[t]!=FWQ;
    }
    int dinic(int s,int t)
    {
        int ans=0;
        for(;spfa(s,t);)
        {
            for(int i=t;i!=s&&i;i=edge[fa[i]^1].to)
            {
                edge[fa[i]].flow--;
                edge[fa[i]^1].flow++;
            }
            ans+=dis[t];
        }
        return ans;
    }
    int Main()
    {
        scanf("%d%d",&F,&V);
        int s=0,t=F+V+1;
        for(int i=1;i<=F;++i) ins(s,i,1,0),ins(i,s,0,0);
        for(int i=F+1;i<=F+V;++i) ins(i,t,1,0),ins(t,i,0,0);
        for(int a,i=1;i<=F;++i)
         for(int j=1;j<=V;++j)
          scanf("%d",&a),ins(i,j+F,1,a),ins(j+F,i,0,-a);
        printf("%d
    ",dinic(s,t));
        return 0;
    }
    int sb=Main();
    int main(int argc,char *argv[]){;}
    我们都在命运之湖上荡舟划桨,波浪起伏着而我们无法逃脱孤航。但是假使我们迷失了方向,波浪将指引我们穿越另一天的曙光。
  • 相关阅读:
    设计模式01之 简单工厂模式(创建模式)
    UML系列05之 基本流程图
    UML系列04之 UML时序图
    UML系列03之 UML类图(二)
    UML系列02之 UML类图(一)
    LaTex in Markdown
    Ubuntu18.04 下的Gif录制工具
    Python3 与 C# 扩展之~基础衍生
    Python3 与 C# 扩展之~模块专栏
    Python3 与 C# 面向对象之~异常相关
  • 原文地址:https://www.cnblogs.com/ruojisun/p/7575845.html
Copyright © 2020-2023  润新知