青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 7,comments - 3,trackbacks - 0
Destroying The Graph
Time Limit: 2000MSMemory Limit: 65536K
Total Submissions: 4718Accepted: 1436Special Judge

Description

Alice and Bob play the following game. First, Alice draws some directed graph with N vertices and M arcs. After that Bob tries to destroy it. In a move he may take any vertex of the graph and remove either all arcs incoming into this vertex, or all arcs outgoing from this vertex. 
Alice assigns two costs to each vertex: Wi+ and Wi-. If Bob removes all arcs incoming into the i-th vertex he pays Wi+ dollars to Alice, and if he removes outgoing arcs he pays Wi- dollars. 
Find out what minimal sum Bob needs to remove all arcs from the graph.

Input

Input file describes the graph Alice has drawn. The first line of the input file contains N and M (1 <= N <= 100, 1 <= M <= 5000). The second line contains N integer numbers specifying Wi+. The third line defines Wi- in a similar way. All costs are positive and do not exceed 106 . Each of the following M lines contains two integers describing the corresponding arc of the graph. Graph may contain loops and parallel arcs.

Output

On the first line of the output file print W --- the minimal sum Bob must have to remove all arcs from the graph. On the second line print K --- the number of moves Bob needs to do it. After that print K lines that describe Bob's moves. Each line must first contain the number of the vertex and then '+' or '-' character, separated by one space. Character '+' means that Bob removes all arcs incoming into the specified vertex and '-' that Bob removes all arcs outgoing from the specified vertex.

Sample Input

3 6
1 2 3
4 2 1
1 2
1 1
3 2
1 2
3 1
2 3

Sample Output

5
3
1 +
2 -
2 +

Source

Northeastern Europe 2003, Northern Subregion



一道典型的最小點權覆蓋問題,SAP速度很好看,之后需要搜索一下用過的點,輸出即可。
代碼:
#include <iostream>
#include 
<cstdio>
#include 
<cstring>
#include 
<cmath>
#define N 10010
#define M 20010
#define inf 1 << 30
#define eps 1 << 29
using namespace std;

int mark[N];
int cnt, n, m, s, t;
int head[N];
int NN;

struct edge
{
    
int v, next, w;
} edge[M];

void addedge(int u, int v, int w)
{
    edge[cnt].v 
= v;
    edge[cnt].w 
= w;
    edge[cnt].next 
= head[u];
    head[u] 
= cnt++;
    edge[cnt].v 
= u;
    edge[cnt].w 
= 0;
    edge[cnt].next 
= head[v];
    head[v] 
= cnt++;
}

int sap()
{
    
int pre[N], cur[N], dis[N], gap[N];
    
int flow = 0, aug = inf, u;
    
bool flag;
    
for (int i = 1; i <= NN; ++i)
    {
        cur[i] 
= head[i];
        gap[i] 
= dis[i] = 0;
    }
    gap[s] 
= NN;
    u 
= pre[s] = s;
    
while (dis[s] < NN)
    {
        flag 
= 0;
        
for (int &= cur[u]; j != -1; j = edge[j].next)
        {
            
int v = edge[j].v;
            
if (edge[j].w > 0 && dis[u] == dis[v] + 1)
            {
                flag 
= 1;
                
if (edge[j].w < aug) aug = edge[j].w;
                pre[v] 
= u;
                u 
= v;
                
if (u == t)
                {
                    flow 
+= aug;
                    
while (u != s)
                    {
                        u 
= pre[u];
                        edge[cur[u]].w 
-= aug;
                        edge[cur[u] 
^ 1].w += aug;
                    }
                    aug 
= inf;
                }
                
break;
            }
        }
        
if (flag)
            
continue;
        
int mindis = NN;
        
for (int j = head[u]; j != -1; j = edge[j].next)
        {
            
int v = edge[j].v;
            
if (edge[j].w > 0 && dis[v] < mindis)
            {
                mindis 
= dis[v];
                cur[u] 
= j;
            }
        }
        
if ((--gap[dis[u]]) == 0)
            
break;
        gap[dis[u] 
= mindis + 1]++;
        u 
= pre[u];
    }
    
return flow;
}

void init()
{
    cnt 
= 0;
    memset(head, 
-1sizeof(head));
    memset(mark, 
0sizeof(mark));
}

void dfs(int x)      //不同于單純的SAP,加入了一個搜素點集元素的函數,通過head數組的記錄信息搜索。
{
    mark[x] 
= 1;
    
for (int i = head[x]; i; i = edge[i].next)
    {
        
if (edge[i].w > 0 && !mark[edge[i].v]) dfs(edge[i].v);
    }
}

int main()
{
    
while (scanf("%d%d"&n, &m) != EOF)
    {
        init();
        
int wp[101], wm[101], w, len = 1, ans[105];
        s 
= 0;
        t 
= 2 * n + 1;
        NN 
= 2 * n + 2;
        
for (int i = 1; i <= n; ++i)
        {
            scanf(
"%d"&wp[i]);
            addedge(i 
+ n, t, wp[i]);
        }
        
for (int i = 1; i <= n; ++i)
        {
            scanf(
"%d"&wm[i]);
            addedge(s, i, wm[i]);
        }
        
for (int i = 1; i <= m; ++i)
        {
            
int x, y;
            scanf(
"%d%d"&x, &y);
            addedge(x, y 
+ n, inf);
        };
        w 
= sap();
        dfs(s);
        
for (int i = 1; i <= n; ++i)
        {
            
if (!mark[i]) ans[len++= i;
            
if (mark[i + n]) ans[len++= i + n;
        }
        len
--;
        printf(
"%d\n%d\n", w, len);
        
for (int i = 1; i <= len; ++i)
        {
            
if (ans[i] <=n) printf("%d -\n", ans[i]);
            
else printf("%d +\n", ans[i] - n);
        }
    }
    
return 0;
}

posted on 2011-10-15 22:09 LLawliet 閱讀(237) 評論(0)  編輯 收藏 引用 所屬分類: 網絡流
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            日韩视频在线观看免费| 午夜视频久久久| 欧美国产一区二区| 模特精品裸拍一区| 99在线观看免费视频精品观看| 最近中文字幕mv在线一区二区三区四区 | 尤物yw午夜国产精品视频| 欧美成人免费网站| 欧美激情中文字幕乱码免费| 亚洲欧美日韩另类| 欧美伊人久久久久久午夜久久久久| 尤物yw午夜国产精品视频| 亚洲激情成人| 国产欧美日韩视频| 欧美国产1区2区| 国产精品成人一区二区三区吃奶| 久久激情综合| 欧美激情精品久久久久久大尺度| 午夜精彩国产免费不卡不顿大片| 午夜免费日韩视频| 日韩视频免费在线| 亚洲在线一区二区三区| 亚洲国产婷婷综合在线精品| 一区二区三区.www| 亚洲高清一二三区| 亚洲综合视频网| 日韩视频免费观看| 欧美在线观看www| 一区二区三区三区在线| 欧美一区二区久久久| 99日韩精品| 久久男女视频| 久久精品最新地址| 国产精品扒开腿爽爽爽视频 | 久久久久久电影| 欧美日本一区二区视频在线观看| 久久精品二区| 欧美日韩在线影院| 欧美电影在线播放| 国产亚洲精品美女| 亚洲手机视频| 一本色道久久综合亚洲精品不卡| 久久精品一区二区国产| 午夜久久久久久| 欧美日韩在线视频一区二区| 欧美丰满高潮xxxx喷水动漫| 国产午夜精品在线观看| 亚洲伊人第一页| 亚洲手机视频| 欧美精品一区视频| 亚洲国产精品一区| 亚洲国产第一| 麻豆freexxxx性91精品| 久久伊人亚洲| 狠狠色香婷婷久久亚洲精品| 性色av一区二区三区红粉影视| 亚洲免费小视频| 国产精品久久九九| 9色porny自拍视频一区二区| 一区二区免费在线观看| 欧美成年人网| 亚洲日韩视频| 国产精品99久久久久久人| 欧美精品在线一区二区| 欧美国产日韩在线观看| 亚洲成色www久久网站| 久久精品国产一区二区三区免费看| 欧美一区二区黄色| 国产一区二区丝袜高跟鞋图片| 性xx色xx综合久久久xx| 久久久99国产精品免费| 国产主播精品| 久久一区二区三区四区| 欧美国产激情二区三区| 亚洲另类在线视频| 欧美日韩在线精品| 亚洲欧美亚洲| 久久女同精品一区二区| 亚洲风情在线资源站| 蜜月aⅴ免费一区二区三区| 亚洲国产精品免费| 一区二区三区波多野结衣在线观看| 欧美日韩免费观看一区| 亚洲午夜av电影| 久久久免费av| 亚洲精品国产品国语在线app| 欧美视频不卡| 久久国产福利| 亚洲精品在线观看视频| 亚洲欧美精品在线观看| 好吊成人免视频| 欧美激情精品久久久| 亚洲香蕉网站| 欧美福利视频在线| 亚洲在线免费视频| 在线免费观看日本欧美| 欧美日韩岛国| 久久精品国产第一区二区三区| 亚洲高清自拍| 久久国产精品亚洲va麻豆| 亚洲人午夜精品| 国产乱人伦精品一区二区| 久久综合色8888| 正在播放亚洲一区| 欧美激情精品久久久久久蜜臀 | 蜜臀av一级做a爰片久久| 99国产精品久久久| 国内一区二区三区| 欧美日韩精品二区第二页| 久久久97精品| 亚洲一区二区三区激情| 亚洲国产精品一区二区久| 久久国产精品一区二区三区四区| 亚洲精品中文字| 激情久久中文字幕| 国产精品国产三级国产普通话蜜臀 | 国产精品毛片在线| 牛夜精品久久久久久久99黑人| 午夜精彩视频在线观看不卡 | 久久中文在线| 性xx色xx综合久久久xx| 99热这里只有成人精品国产| 在线国产欧美| 国内精品国产成人| 国产精品久久久久久久久搜平片| 免费成人黄色片| 久久久欧美精品sm网站| 欧美亚洲视频一区二区| 在线亚洲欧美| 日韩亚洲欧美精品| 亚洲黄色成人| 欧美激情在线狂野欧美精品| 蜜桃av一区二区三区| 久久综合图片| 久久亚洲欧美国产精品乐播| 久久精品国产77777蜜臀| 午夜一区不卡| 久久本道综合色狠狠五月| 亚洲欧洲av一区二区| 亚洲一区精品在线| 亚洲校园激情| 亚洲免费视频网站| 午夜精彩视频在线观看不卡| 亚洲欧美日韩天堂一区二区| 亚洲综合电影一区二区三区| 午夜欧美不卡精品aaaaa| 羞羞答答国产精品www一本 | 亚洲精品小视频在线观看| 亚洲国产乱码最新视频| 亚洲国产精品视频| 亚洲精品美女在线观看| 在线视频精品一区| 亚洲婷婷在线| 欧美在线www| 久久综合久久88| 欧美韩国日本综合| 最新69国产成人精品视频免费| 亚洲精品一区二区三区婷婷月 | 午夜久久福利| 久久久精品一品道一区| 久久天天狠狠| 欧美日本久久| 国产精品一区一区三区| 在线观看视频免费一区二区三区| 亚洲人永久免费| 亚洲欧美精品伊人久久| 久久精品夜色噜噜亚洲a∨ | 亚洲人成高清| 一区二区三区黄色| 久久爱另类一区二区小说| 欧美成人精品三级在线观看| 国产精品成人午夜| 国产一区二区三区高清播放| 亚洲欧洲一区二区三区| 亚洲免费影视| 男女精品视频| 亚洲一二三级电影| 久久久久久一区二区| 欧美日韩视频| 在线观看欧美日韩| 亚洲欧美日韩国产一区| 欧美xx视频| 亚洲男女自偷自拍| 欧美成人一区二区三区片免费| 国产精品久久久久av| 亚洲国产高清一区二区三区| 亚洲欧美日韩精品久久久| 女仆av观看一区| 亚洲欧美日韩中文在线制服| 欧美成人综合在线| 狠狠色丁香婷婷综合| 亚洲一区免费网站| 欧美国产极速在线| 欧美一级视频精品观看| 欧美午夜视频网站| 最新国产精品拍自在线播放| 久久久女女女女999久久| 亚洲一区二区三区在线看| 欧美岛国激情| 亚洲第一在线综合在线|