zoukankan      html  css  js  c++  java
  • 「网络流 24 题」圆桌聚餐

    网络流水题,详细看代码

     1 #include<bits/stdc++.h>
     2 using namespace std;
     3 
     4 int n,m,tot=-1,h[3005],ans=0,sum=0;
     5 struct node{
     6     int from,next,to,rest,full;
     7     int last;
     8 }e[100005];
     9 void add(int x,int y,int z){
    10     tot++;
    11     e[tot].next=h[x];
    12     h[x]=tot;
    13     e[tot].from=x;
    14     e[tot].to=y;
    15     e[tot].rest=z;
    16     e[tot].full=z;
    17 }
    18 
    19 int dis[3005],g[3005],flow[3005];
    20 bool vis[3005];
    21 
    22 int bfs(int s,int t){
    23     queue<int>q;
    24     dis[s]=0;
    25     q.push(s);vis[s]=true;
    26     while(!q.empty()){
    27         int u=q.front();vis[u]=false;q.pop();
    28         for(int i=h[u];i!=(-1);i=e[i].next){
    29             if(dis[e[i].to]>dis[u]+1&&g[e[i].to]==(-1)&&e[i].rest>0){
    30                 g[e[i].to]=i;
    31                 flow[e[i].to]=min(flow[u],e[i].rest);
    32                 dis[e[i].to]=dis[u]+1;
    33                 if(vis[e[i].to]==false){
    34                     vis[e[i].to]=true;
    35                     q.push(e[i].to);
    36                 }
    37             }
    38         }
    39     }
    40 }
    41 
    42 int EK(int s,int t){
    43     while(1){
    44         memset(vis,false,sizeof(vis));
    45         memset(dis,0x7f,sizeof(dis));
    46         memset(flow,0x7f,sizeof(flow));
    47         memset(g,-1,sizeof(g));
    48         bfs(s,t);
    49         if(g[t]==(-1))return 0;
    50         ans+=flow[t];
    51         for(int p=t;p!=(s);p=e[g[p]].from){
    52             e[g[p]].rest-=flow[t];
    53             e[g[p]^1].rest+=flow[t];
    54         }    
    55         
    56     }
    57 }
    58 
    59 int main(){
    60     memset(h,-1,sizeof(h));
    61     cin>>m>>n;
    62     for(int i=1;i<=m;i++){
    63         int co;cin>>co;sum+=co;
    64         add(0,i,co);
    65         add(i,0,0);
    66         for(int j=1;j<=n;j++){
    67             add(i,j+m,1);
    68             add(j+m,i,0);
    69         }
    70     }
    71     for(int i=1;i<=n;i++){
    72         int co;cin>>co;
    73         add(i+m,n+m+1,co);
    74         add(n+m+1,i+m,0);
    75     }
    76     EK(0,n+m+1);
    77     if(sum>ans){
    78         cout<<0<<endl;
    79         exit(0);
    80     }
    81     cout<<1<<endl;
    82     for(int i=1;i<=m;i++){
    83         for(int j=h[i];j!=(-1);j=e[j].next){
    84             if(e[j].to!=0&&e[j].rest==0){
    85                 cout<<e[j].to-m<<" ";
    86             }
    87         }
    88         cout<<endl;
    89     }
    90 }
    View Code
  • 相关阅读:
    flexible.js 移动端自适应方案
    Vue为什么不能检测数组变动
    Vue 组件间通信六种方式
    训练首个神经网络:基本分类
    对seq2seq的粗浅认识
    数学模型的过拟合和欠拟合
    在二叉树中寻找值最大的节点并返回——LintCode入门
    Android 包管理机制
    自定义View的三种实现方式及自定义属性使用介绍
    Paint.setFlags中flag意义及使用方法
  • 原文地址:https://www.cnblogs.com/shatianming/p/12227600.html
Copyright © 2011-2022 走看看