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

syhd142  
日歷
<2025年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011
統(tǒng)計
  • 隨筆 - 23
  • 文章 - 122
  • 評論 - 31
  • 引用 - 0

導(dǎo)航

常用鏈接

留言簿(2)

隨筆檔案(23)

文章分類(270)

文章檔案(122)

我的豆瓣

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

 
逃脫問題,在算法導(dǎo)論網(wǎng)絡(luò)流后面的習(xí)題里面有提到,就是一個點不相交的路徑,要拆點,導(dǎo)致圖很大,我的鄰接矩陣isap超時,換成鄰接表還是超時。。
就拿人家的代碼交了,思想還是簡單的。我的網(wǎng)路流模板當(dāng)圖一大就超時。。真杯具。
#include <iostream>
#include 
<vector>
#include 
<queue>
// 50 * 50 * 2 + 2 = 5002
#define MAX 5002
#define RESIDUE(s,t) (capacity[s][t]-flow[s][t])

using namespace std;

int dr[4= {010-1};
int dc[4= {10-10};
int bank[MAX][2];
int flow[MAX][MAX];
int capacity[MAX][MAX];
int s, a, b;
int prev[MAX];

inline 
int getSourceID() { return s * a * 2; }
inline 
int getDestinationID() { return s * a * 2 + 1; }
inline 
int getIDByRowCol(int r, int c, int rank) { return r * a + c + rank * s * a; }
inline 
void getRowColByID(int id, int &row, int &col, int &rank) {
  rank 
= id >= s * a; id %= s * a;
  row 
= id / a;
  col 
= id % a;
}
inline 
bool isValid(int r, int c) { return 0 <= r && r < s && 0 <= c && c < a; }
inline 
bool isOnEdge(int r, int c) { return r == 0 || r == s - 1 || c == 0 || c == a - 1; }

void display(int id) {
  
if (prev[id] != id) {
    display(prev[id]);
  }
  
if (id == getSourceID()) {
    cout 
<< "source" << endl;
  } 
else if (id == getDestinationID()) {
    cout 
<< "destination" << endl;
  } 
else {
    
int row, col, rank;
    getRowColByID(id, row, col, rank);
    cout 
<< row + 1 << " " << col + 1;
    
if (rank) cout << " shadow";
    cout 
<< endl;
  }
}

main () {
  
int p;
  cin 
>> p;
  
for (int P = 0; P < p; ++P) {
    
// Input
    cin >> s >> a >> b;
    
for (int i = 0; i < b; ++i) {
      cin 
>> bank[i][0>> bank[i][1];
      bank[i][
0]--, bank[i][1]--;
    }

    
// Initialize
    memset(capacity, 0sizeof(capacity));
    memset(flow, 
0sizeof(flow));
    
// Source to banks
    for (int i = 0; i < b; ++i) {
      capacity[getSourceID()][getIDByRowCol(bank[i][
0], bank[i][1], 0)] = 1;
    }
    
// Adjacent grid
    for (int i = 0; i < s; ++i) {
      
for (int j = 0; j < a; ++j) {
        
int fromID = getIDByRowCol(i, j, 0);
        
int _fromID = getIDByRowCol(i, j, 1);
        capacity[_fromID][fromID] 
= 1;
        
for (int k = 0; k < 4++k) {
          
int ni = i + dr[k];
          
int nj = j + dc[k];
          
if (!isValid(ni, nj)) continue;
          
int toID = getIDByRowCol(ni, nj, 1);
          capacity[fromID][toID] 
= 1;
        }
      }
    }
    
// Grids on edge to destination
    for (int i = 0; i < s; ++i) {
      capacity[getIDByRowCol(i, 
00)][getDestinationID()] = 1;
      capacity[getIDByRowCol(i, a 
- 10)][getDestinationID()] = 1;
    }
    
for (int j = 0; j < a; ++j) {
      capacity[getIDByRowCol(
0, j, 0)][getDestinationID()] = 1;
      capacity[getIDByRowCol(s 
- 1, j, 0)][getDestinationID()] = 1;
    }
    
// If a bank exists on a corner, transition between
    
// surface and shadow is forbidden.
    for (int i = 0; i < b; ++i) {
      capacity[getIDByRowCol(bank[i][
0], bank[i][1], 1)][getIDByRowCol(bank[i][0], bank[i][1], 0)] = 0;
    }

    
// Maxflow
    int total = 0;
    
while (1) {
      queue
<int> que; que.push(getSourceID());
      memset(prev, 
-1sizeof(prev)); prev[getSourceID()] = getSourceID();
      
while (!que.empty() && prev[getDestinationID()] == -1) {
        
int u = que.front(); que.pop();
        vector
<int> nextID;
        
if (u == getSourceID()) {
          
for (int i = 0; i < b; ++i) {
            
//cout << bank[i][0] << " " << bank[i][1] << ", id = " << getIDByRowCol(bank[i][0], bank[i][1], 0) << endl;
            nextID.push_back(getIDByRowCol(bank[i][0], bank[i][1], 0));
          }
        } 
else {
          
int row, col, rank;
          getRowColByID(u, row, col, rank);
          
//cout << u << " " << row << " " << col << " " << rank << endl;
          if (rank == 0 && isOnEdge(row, col)) {
            nextID.push_back(getDestinationID());
          } 
else if (rank == 1) {
            nextID.push_back(getIDByRowCol(row, col, 
0));
          } 
else {
            
for (int i = 0; i < 4++i) {
              
int nrow = row + dr[i];
              
int ncol = col + dc[i];
              
if (!isValid(nrow, ncol)) continue;
              nextID.push_back(getIDByRowCol(nrow, ncol, 
1));
            }
          }
        }
        
for (int i = 0; i < nextID.size(); ++i) {
          
int v = nextID[i];
          
if (prev[v] == -1 && RESIDUE(u, v) > 0) {
            prev[v] 
= u;
            que.push(v);
          }
        }
      }
      
if (prev[getDestinationID()] == -1break;
      
int inc = INT_MAX;
      
for (int j = getDestinationID(); prev[j] != j; j = prev[j]) {
        inc 
= min(inc, RESIDUE(prev[j], j));
      }
      
for (int j = getDestinationID(); prev[j] != j; j = prev[j]) {
        flow[prev[j]][j] 
+= inc, flow[j][prev[j]] -= inc;
      }
      
//display(getDestinationID()); cout << endl;
      total += inc;
    }
    
//cout << total << endl;
    if (total == b) {
      cout 
<< "possible" << endl;
    } 
else {
      cout 
<< "not possible" << endl;
    }
  }
}
posted on 2010-07-14 19:04 Fucker 閱讀(465) 評論(0)  編輯 收藏 引用 所屬分類: ACM/ICPC圖論
 
Copyright © Fucker Powered by: 博客園 模板提供:滬江博客
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久青青草原一区二区| 亚洲一区二区三区在线观看视频 | 久久久777| 欧美亚洲午夜视频在线观看| 国产日韩专区在线| 老司机午夜精品| 欧美大学生性色视频| 一本到高清视频免费精品| 99国产精品久久久| 国产日韩欧美在线播放不卡| 久久亚洲综合| 欧美一级午夜免费电影| 欧美一区二区三区四区在线观看地址| 狠狠干综合网| 亚洲国产精品精华液网站| 欧美日韩福利| 久久精品视频网| 欧美激情女人20p| 久久国产99| 欧美成人免费全部观看天天性色| 亚洲天堂激情| 久久色在线观看| 亚洲主播在线观看| 久久久青草婷婷精品综合日韩| 亚洲精品视频免费观看| 亚洲午夜高清视频| 亚洲国产成人精品久久| 亚洲香蕉伊综合在人在线视看| 国外成人在线| 一区二区三区欧美成人| 在线观看亚洲| 亚洲午夜av在线| 亚洲美女视频网| 久久9热精品视频| 亚洲欧美视频在线| 欧美日本国产| 女主播福利一区| 国产情侣一区| 99国产精品久久久| 亚洲精选国产| 久久色中文字幕| 久久久噜噜噜久久| 国产精品初高中精品久久| 欧美韩日一区| 国内精品久久久久影院薰衣草| 一本久久青青| 艳妇臀荡乳欲伦亚洲一区| 久久综合给合久久狠狠狠97色69| 亚洲欧美一区二区激情| 欧美日韩视频免费播放| 欧美激情精品久久久久久| 国模套图日韩精品一区二区| 亚洲伊人久久综合| 亚洲性夜色噜噜噜7777| 欧美日韩国产在线观看| 亚洲国产欧美日韩| 亚洲承认在线| 久久性色av| 欧美电影免费观看| 亚洲国产高清一区| 久久久综合激的五月天| 久久综合久久综合九色| 国内精品久久久久久影视8| 欧美一级久久久| 欧美一区二区免费视频| 国产欧美va欧美不卡在线| 亚洲综合精品自拍| 午夜国产欧美理论在线播放| 国产精品xvideos88| 亚洲一区二区三区激情| 欧美亚洲一区在线| 国产精品―色哟哟| 亚洲欧美日韩一区二区三区在线观看| 欧美一区二区视频免费观看| 国产亚洲一区二区三区在线播放| 香蕉久久一区二区不卡无毒影院| 久久成人免费网| 精品动漫一区二区| 久久久精品网| 极品少妇一区二区| 欧美精品一区二区三区在线看午夜| 亚洲国产精品激情在线观看| 亚洲四色影视在线观看| 国产欧美一区二区三区国产幕精品| 欧美亚洲综合在线| 欧美大片一区| 亚洲一二三区在线| 国产日韩1区| 免费成人在线观看视频| 最新国产成人在线观看| 亚洲综合色视频| 国产日韩在线看片| 狂野欧美一区| 亚洲视频在线观看网站| 老牛嫩草一区二区三区日本| 日韩视频免费大全中文字幕| 国产精品蜜臀在线观看| 久久五月天婷婷| a91a精品视频在线观看| 久久久五月婷婷| 在线视频精品一区| 韩日精品视频| 欧美日韩一二三四五区| 亚洲欧美日本伦理| 亚洲激情在线视频| 欧美日韩精品是欧美日韩精品| 午夜精彩国产免费不卡不顿大片| 欧美成人免费视频| 久久av最新网址| 日韩午夜高潮| 国内激情久久| 国产精品久久久久久五月尺| 欧美+日本+国产+在线a∨观看| 亚洲天堂偷拍| 亚洲三级视频| 欧美电影免费观看| 久久国内精品自在自线400部| 9久草视频在线视频精品| 国内精品伊人久久久久av一坑| 欧美日韩中文字幕在线视频| 免费中文字幕日韩欧美| 久久福利电影| 亚洲午夜久久久久久尤物| 亚洲茄子视频| 亚洲福利国产| 老牛国产精品一区的观看方式| 欧美亚洲视频在线观看| 亚洲伊人第一页| 一区二区三区欧美视频| 最新国产成人在线观看| 影音先锋日韩精品| 国产欧美日韩精品a在线观看| 欧美日韩国产成人精品| 欧美日韩成人精品| 欧美久久久久中文字幕| 欧美国产一区二区三区激情无套| 开元免费观看欧美电视剧网站| 欧美尤物巨大精品爽| 欧美一区二区三区在线视频| 亚洲一区二区三区精品在线| 一区二区免费在线观看| 亚洲一区二区三区高清| 亚洲国产成人久久| 亚洲精品久久久久久久久久久| 美女诱惑黄网站一区| 你懂的成人av| 欧美激情综合色| 欧美激情bt| 红桃视频欧美| 一区在线观看视频| 亚洲高清资源| 一本久道久久久| 亚洲男人的天堂在线观看| 亚洲免费影院| 久久精品一区二区三区中文字幕 | 亚洲欧美999| 性亚洲最疯狂xxxx高清| 久久全球大尺度高清视频| 久久久亚洲午夜电影| 欧美国产日产韩国视频| 最近中文字幕日韩精品| 99精品欧美一区二区蜜桃免费| 亚洲天堂偷拍| 久久婷婷国产综合尤物精品| 欧美成人免费在线| 国产精品久久波多野结衣| 狠狠狠色丁香婷婷综合久久五月| 亚洲激情六月丁香| 亚洲午夜精品久久久久久浪潮| 欧美一区二区三区在线播放| 免费看的黄色欧美网站| 亚洲理论在线观看| 亚洲欧美中文另类| 蜜臀久久久99精品久久久久久| 欧美日韩午夜剧场| 国产亚洲精品bv在线观看| 亚洲激情女人| 欧美一区二区日韩| 亚洲国产老妈| 欧美一区二区三区四区在线观看地址 | 国产精品久久久久aaaa| 在线精品国产成人综合| 亚洲特色特黄| 美日韩精品视频| 在线一区二区三区做爰视频网站 | 美女999久久久精品视频| 欧美日本国产视频| 精品69视频一区二区三区| 亚洲视频1区2区| 牛牛影视久久网| 亚洲一级电影| 欧美久久综合| 在线不卡中文字幕| 午夜精品国产更新| 亚洲精品社区| 免费一级欧美在线大片| 国产一区二区三区久久| 亚洲一区二区在线免费观看| 欧美国产视频一区二区| 久久成人在线|