752. [BJOI2006] 狼抓兔子

来源:http://www.cnblogs.com/zwfymqz/archive/2017/07/29/7256756.html
-Advertisement-
Play Games

★★★ 輸入文件:bjrabbit.in 輸出文件:bjrabbit.out 簡單對比時間限制:1 s 記憶體限制:162 MB Description Source: Beijing2006 [BJOI2006] 八中OJ上本題鏈接:http://www.lydsy.com/JudgeOnline/ ...


★★★   輸入文件:bjrabbit.in   輸出文件:bjrabbit.out   簡單對比
時間限制:1 s   記憶體限制:162 MB

Description   Source: Beijing2006 [BJOI2006]

八中OJ上本題鏈接:http://www.lydsy.com/JudgeOnline/problem.php?id=1001

現在小朋友們最喜歡的"喜羊羊與灰太狼",話說灰太狼抓羊不到,但抓兔子還是比較在行的,而且現在的兔子還比較笨,它們只有兩個窩,現在你做為狼王,面對下麵這樣一個網格的地形:

 

左上角點為(1,1),右下角點為(N,M)(上圖中N=4,M=5).有以下三種類型的道路 1:(x,y)<==>(x+1,y) 2:(x,y)<==>(x,y+1) 3:(x,y)<==>(x+1,y+1) 道路上的權值表示這條路上最多能夠通過的兔子數,道路是無向的. 左上角和右下角為兔子的兩個窩,開始時所有的兔子都聚集在左上角(1,1)的窩裡,現在它們要跑到右下解(N,M)的窩中去,狼王開始伏擊這些兔子.當然為了保險起見,如果一條道路上最多通過的兔子數為K,狼王需要安排同樣數量的K只狼,才能完全封鎖這條道路,你需要幫助狼王安排一個伏擊方案,使得在將兔子一網打盡的前提下,參與的狼的數量要最小。因為狼還要去找喜羊羊麻煩.

Input

第一行為N,M.表示網格的大小,N,M均小於等於1000.接下來分三部分 第一部分共N行,每行M-1個數,表示橫向道路的權值. 第二部分共N-1行,每行M個數,表示縱向道路的權值. 第三部分共N-1行,每行M-1個數,表示斜向道路的權值. 輸入文件保證不超過10M

Output

輸出一個整數,表示參與伏擊的狼的最小數量.

Sample Input

3 4
5 6 4
4 3 1
7 5 3
5 6 7 8
8 7 6 5
5 5 5
6 6 6

Sample Output

14     如果你想到了一個定理: 最大流==最小割, 然後聰明的想到了Dinic跑最大流 那麼恭喜你, 被坑了,。。, 因為這道題的數據範圍比較大 Dinic肯定跑步過去, 所以考慮用對偶圖跑最短路, 至於為什麼,,,我也不太懂,, 特別是代碼。。  
  1 #include<iostream>
  2 #include<cstdio>
  3 #include<cstring>
  4 #include<cmath>
  5 #include<queue>
  6 #include<algorithm>
  7 using namespace std;
  8 const int MAXN=6000002;
  9 const int MAXM=6000002;
 10 const int maxn=0x7fffffff;
 11 inline void read(int &n)
 12 {
 13     char c='+';int x=0;bool flag=0;
 14     while(c<'0'||c>'9'){c=getchar();if(c=='-')flag=1;}
 15     while(c>='0'&&c<='9'){x=x*10+(c-48);c=getchar();}
 16     flag==1?n=-x:n=x;
 17 }
 18 struct node
 19 {
 20     int u,v,f,nxt;
 21 }edge[MAXM];
 22 int head[MAXN];
 23 int num=1;
 24 int n,m;
 25 int dis[MAXN];
 26 bool vis[MAXN];
 27 inline void add_edge(int x,int y,int z)
 28 {
 29     edge[num].u=x;
 30     edge[num].v=y;
 31     edge[num].f=z;
 32     edge[num].nxt=head[x];
 33     head[x]=num++;
 34 }
 35 inline void SPFA(int s,int t)
 36 {
 37     for(int i=0;i<t;i++)
 38         dis[i]=maxn;
 39     dis[s]=0;
 40     vis[s]=1;
 41     queue<int>q;
 42     q.push(s);
 43     while(q.size()!=0)
 44     {
 45         int p=q.front();
 46         q.pop();
 47         vis[p]=0;
 48         for(int i=head[p];i!=-1;i=edge[i].nxt)
 49         {
 50             if(dis[edge[i].v]>dis[edge[i].u]+edge[i].f)
 51             {
 52                 dis[edge[i].v]=dis[edge[i].u]+edge[i].f;
 53                 if(vis[edge[i].v]==0)
 54                 {
 55                     vis[edge[i].v]=1;
 56                     q.push(edge[i].v);
 57                 }
 58             }
 59         }
 60     }
 61     printf("%d",dis[t]);
 62 }
 63 int main()
 64 {
 65     //freopen("bjrabbit.in","r",stdin);
 66     //freopen("bjrabbit.out","w",stdout);
 67     read(n);read(m);
 68     memset(head,-1,sizeof(head));
 69     int from=0;
 70     int to=(2*(n-1)*(m-1))+1;
 71     int spend,x,y;
 72     for(int i=1;i<=n;i++)
 73         for(int j=1;j<m;j++)
 74         {
 75             read(spend);
 76             x= i==1? from: (2*(i-1)-1)*(m-1)+j;
 77             y= i==n? to : (2*(i-1))*(m-1)+j;
 78         //    printf("%d %d %d \n",x,y,spend);
 79             add_edge(x,y,spend);
 80             add_edge(y,x,spend);
 81         }
 82     for(int i=1;i<n;i++)
 83         for(int j=1;j<=m;j++)
 84         {
 85             read(spend);
 86             x= j==1?to:(2*(i-1))*(m-1)+j-1;
 87             y= j==m?from:(2*(i-1))*(m-1)+j-1+m;
 88             //printf("%d %d %d \n",x,y,spend);
 89             add_edge(x,y,spend);
 90             add_edge(y,x,spend);
 91         }
 92     for(int i=1;i<n;i++)
 93         for(int j=1;j<m;j++)
 94         {
 95             read(spend);
 96             x=(2*(i-1))*(m-1)+j;
 97             y=(2*(i-1)+1)*(m-1)+j;
 98             //printf("%d %d %d \n",x,y,spend);
 99             add_edge(x,y,spend);
100             add_edge(y,x,spend);
101         }
102     SPFA(from,to);
103     return 0;
104 }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 首先,這是我對自己的需求而使用的邏輯,若有可以完美的地方方便告訴下小白。 MAVEN 1、前端頁面,偽非同步(頁面不刷新) 為什麼不用ajax呢? JQuery的ajax函數的返回類型只有xml、text、json、html等類型,沒有“流”類型。所以就用js做個form表單請求 上代碼 2、在工具包 ...
  • 爬取前的準備: BeautifulSoup的導入:pip install BeautifulSoup4 requests的導入:pip install requests 下載jupyter notebook:pip install jupyter notebook 下載python,配置環境(可使用 ...
  • ArrayList是java中使用頻率非常高的一個集合類,它的底層採用數組來實現,本文主要來探究一下其源碼,幫助記憶和理解。 ...
  • import tornado.ioloop import tornado.web class MainHanlwe(tornado.web.RequestHandler): def get(self): login_user=self.get_secure_cookie('login_user',N... ...
  • username = "Anker" passward = "Abc123" number =2 for i in range(1,4,1): _username = input("username:") _passward = input("passward:") if _username==us ...
  • 一直都想寫點什麼,卻一直停滯……主要是因為有點懶,同時又想對所發的任何一篇博文都有很高的要求。 在學Python包括其擴展庫的過程中記錄過很多筆記,只是按自己的習慣所記,直接貼出來其他人不一定看得懂。在這裡發文畢竟都是要給別人看的,所以覺得發出來至少也得條理清晰,邏輯嚴密,才不至於誤導了閱讀我的博文 ...
  • 繼承PagingAndSortingRepository 我們可以看到,BlogRepository定義了這樣一個方法:Page<Blog> findByDeletedFalse(Pageable pageable);,我們主要關註它的參數以及返回值。 Pageable 是Spring Data庫中 ...
  • CrudRepository 的主要方法 1. 新建一個類 CurdEmployeeRespository 繼承CrudRepository 裡面實現了大量的增刪改查方法 2. 編寫service實現類 編寫測試類 測試結果 因為我測試前把數據全部都刪除了 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...