BZOJ1179 Atm //縮點+spfa

1179: [Apio2009]Atm

Description

Input

第一行包含兩個整數N、M。N表示路口的個數,M表示道路條數。接下來M行,每行兩個整數,這兩個整數都在1到N之間,第i+1行的兩個整數表示第i條道路的起點和終點的路口編號。接下來N行,每行一個整數,按順序表示每個路口處的ATM機中的錢數。接下來一行包含兩個整數S、P,S表示市中心的編號,也就是出發的路口。P表示酒吧數目。接下來的一行中有P個整數,表示P個有酒吧的路口的編號

Output

輸出一個整數,表示Banditji從市中心開始到某個酒吧結束所能搶劫的最多的現金總數。

Sample Input

6 7
1 2
2 3
3 5
2 4
4 1
2 6
6 5
10
12
8
16
1
5
1 4
4
3
5
6

Sample Output

47

HINT

50%的輸入保證N, M<=3000。所有的輸入保證N, M<=500000。每個ATM機中可取的錢數為一個非負整數且不超過4000。輸入數據保證你可以從市中心沿著Siruseri的單向的道路到達其中的至少一個酒吧。

分析:

這道題其實很迷。首先這道題發現如果在一個強連通分量里面,都可以走到,而且也沒有限制走的次數,所以我們可以將在強連通分量里面的點,縮成一個全新的點。之后造出來一個全新的圖。boom!新造出來的圖可以走一遍最短路spfa。就好了。

至于怎么縮點。
用并查集先找到父親與兒子。之后每次判斷出一個強量通分量就用將他們的父親全連成第一個數。
之后在新建圖(如果一個點的父親與兒子的父親不相同,那他們1,連上2,建邊)
這個邊其實可以重復利用。這樣可以節省空間。

#include<cstdio>
#include<string.h>
#include<algorithm>
using namespace std;
struct node{int infont,v,next,val;
}edge[1000010];
int strack[1000010],cnt,father[1000000],heads[500010],d[500010],s,p;
int DFN[1000000],LOW[1000000],bar[1000000],visit[1000010],du[500010];
int n,m,index_1,head;
void address(int x,int y){edge[++cnt].infont=x;edge[cnt].v=y;edge[cnt].next=heads[x];heads[x]=cnt;return ;
}
void tarjan(int x){LOW[x]=DFN[x]=++index_1;visit[x]=1;strack[++head]=x;for(int i=heads[x];i!=-1;i=edge[i].next){if(!DFN[edge[i].v]){tarjan(edge[i].v);LOW[x]=min(LOW[x],LOW[edge[i].v]);}else if(visit[edge[i].v]){LOW[x]=min(LOW[x],DFN[edge[i].v]);}}if(LOW[x]==DFN[x]){while(strack[head]!=x){visit[strack[head]]=0;d[x]+=d[strack[head]];father[strack[head]]=x;head--;}head--;visit[x]=0;}return ;
}
void build(){memset(heads,-1,sizeof(heads));cnt=0;for(int i=1;i<=m;++i){if(father[edge[i].infont]!=father[edge[i].v])address(father[edge[i].infont],father[edge[i].v]);}return ;
}
void SPFA(int x)
{memset(visit,0,sizeof(visit));memset(strack,0,sizeof(strack));memset(du,-0x3f,sizeof(du));int last;last=head=1;strack[head]=x;visit[x]=1;du[x]=d[x];while(head<=last){int news=strack[head];for(int i=heads[news];i!=-1;i=edge[i].next){if(du[edge[i].v]<du[news]+d[edge[i].v]){du[edge[i].v]=du[news]+d[edge[i].v];if(visit[edge[i].v])continue;visit[edge[i].v]=1;strack[++last]=edge[i].v;}}head++;visit[news]=0;}return ;
}
int main( ){memset(heads,-1,sizeof(heads));scanf("%d%d",&n,&m);int a,b;for(int i=1;i<=m;++i){scanf("%d%d",&a,&b);address(a,b);}for(int i=1;i<=n;++i){scanf("%d",&a);d[i]=a;father[i]=i;}for(int i=1;i<=n;++i)if(!DFN[i])tarjan(i);build();scanf("%d%d",&a,&b);SPFA(father[a]);int ans=0;for(int i=1;i<=b;++i){scanf("%d",&a);ans=max(ans,du[father[a]]);}printf("%d",ans);return 0;
}

轉載于:https://www.cnblogs.com/uncle-lu/p/5970686.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/285845.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/285845.shtml
英文地址,請注明出處:http://en.pswp.cn/news/285845.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

centos 新建swap區文件

一. 相當詳細且流程完整&#xff0c;&#xff08;推薦閱讀&#xff09; 在centos7上新建swap區 https://www.digitalocean.com/community/tutorials/how-to-add-swap-on-centos-7 二. centos官網 轉&#xff1a;https://www.centos.org/docs/5/html/5.2/Deployment_Guide/s2-sw…

ArcGIS實驗教程——實驗三十六:ArcGIS Python腳本的巧妙使用

ArcGIS實驗視頻教程合集:《ArcGIS實驗教程從入門到精通》(附配套實驗數據)》 文章目錄 一、ArcGIS腳本簡介二、Python腳本與ArcPy三、Python窗口四、腳本編寫(案例:矢量數據批量裁剪)五、在ModelBuilder中使用腳本工具一、ArcGIS腳本簡介 腳本與模型相似,也是把處理過程…

基于Spring Boot和Spring Cloud實現微服務架構學習

目錄 Spring 頂級框架 Spring cloud子項目 WHAT - 什么是微服務 微服務簡介 微服務的具體特征 SOA vs Microservice HOW - 怎么具體實踐微服務 客戶端如何訪問這些服務&#xff1f; 服務之間如何通信&#xff1f; 這么多服務&#xff0c;怎么找? 這么多服務&#x…

C語言試題七十七之請編寫函實現漁夫打魚曬網問題

??個人主頁:個人主頁 ??系列專欄:C語言試題200例目錄 ??推薦一款刷算法、筆試、面經、拿大公司offer神器 ?? 點擊跳轉進入網站 ?作者簡介:大家好,我是碼莎拉蒂,CSDN博客專家(全站排名Top 50),阿里云博客專家、51CTO博客專家、華為云享專家 1、題目 編寫函數:…

.NetCore實現圖片縮放與裁剪 - 基于ImageSharp

前言&#xff08;突然發現斷更有段時間了最近在做博客的時候&#xff0c;需要實現一個類似Lorempixel、LoremPicsum這樣的隨機圖片功能&#xff0c;圖片有了&#xff0c;還需要一個根據輸入的寬度高度獲取圖片的功能&#xff0c;由于之前處理圖片時使用到了ImageSharp庫&#x…

Mysql身份認證漏洞及利用(CVE-2012-2122) 補充測試用例

當連接MariaDB/MySQL時&#xff0c;輸入的密碼會與期望的正確密碼比較&#xff0c;由于不正確的處理&#xff0c;會導致即便是memcmp()返回一個非零值&#xff0c;也會使MySQL認為兩個密碼是相同的。也就是說只要知道用戶名&#xff0c;不斷嘗試就能夠直接登入SQL數據庫。按照公…

添加啟動類

添加.h和cpp #pragma once #include "afxwin.h" class mySplash :public CWnd {DECLARE_DYNAMIC(mySplash)protected:DECLARE_MESSAGE_MAP()public:CBitmap m_bitmap;void Create(UINT nBitmapID);afx_msg void OnPaint();afx_msg void OnTimer(UINT_PTR nIDEvent); …

ArcGIS實驗教程——實驗三十七:基于ArcGIS的太陽輻射分析案例教程

ArcGIS實驗視頻教程合集:《ArcGIS實驗教程從入門到精通》(附配套實驗數據)》 文章目錄 一、太陽輻射的基本概念1. 視域2. 太陽圖3. 星空圖二、太陽輻射ArcGIS案例實現1. 對該區域進行太陽輻射區域分析2. 對單個點的太陽輻射進行分析太陽輻射是地球上各種物理過程和生物過程的…

C語言試題七十八之請編寫函實現求2個數的最大公約數和最小公倍數(輾轉相除法)

??個人主頁:個人主頁 ??系列專欄:C語言試題200例目錄 ??推薦一款刷算法、筆試、面經、拿大公司offer神器 ?? 點擊跳轉進入網站 ?作者簡介:大家好,我是碼莎拉蒂,CSDN博客專家(全站排名Top 50),阿里云博客專家、51CTO博客專家、華為云享專家 1、題目 求2個數的…

restful-api-design-references

之所以創建這個 repository&#xff0c;是因為我希望收集一些比較好的有關于 RESTful API 設計的參考文獻。偶爾回顧&#xff0c;偶爾改進&#xff0c;大家一起來吧~ 如果你有更好的私藏文章&#xff0c;不凡分享出來&#xff0c;獨樂樂不如眾樂樂&#xff0c;(⊙o⊙) RESTful…

jQuery 3.4.0 Released(2019.4.10)

jQuery has a new release! It’s been a while since our last release, but we expect this to be the last minor release in the 3.x branch, and then we will move on to the overhaul that will be jQuery 4.0. But before we get to 4.0, we’re excited to share the …

C#-Linq源碼解析之DefaultIfEmpty

前言在Dotnet開發過程中&#xff0c;DefaultIfEmpty作為IEnumerable的擴展方法&#xff0c;十分常用。本文對DefaultIfEmpty方法的關鍵源碼進行簡要分析&#xff0c;以方便大家日后更好的使用該方法。使用DefaultIfEmpty 返回 IEnumerable< T> 的元素&#xff1b;如果序列…

ArcGIS實驗教程——實驗三十八:基于ArcGIS的等高線、山體陰影、山頂點提取案例教程

ArcGIS實驗視頻教程合集:《ArcGIS實驗教程從入門到精通》(附配套實驗數據)》 文章目錄 1. 加載DEM2. 提取等高距為15m的等高線3. 提取等高距為75m的等高線4. 生成山體陰影5. 生成三維等高線6. 提取山頂點7. 實驗數據下載地址山頂點指那些在特定鄰域分析范圍內,該點都比周圍…

Zabbix3.0 安裝Graphtree

zabbix中&#xff0c;想要集中展示圖形&#xff0c;唯一的選擇是screen&#xff0c;zatree可以解決這個問題&#xff0c;但是性能不是很好。 Graphtree由OneOaas開發并開源出來&#xff0c;用來解決zabbix的圖形展示問題&#xff0c;性能比較好 因為默認的zabbix 展示圖形很麻煩…

(2.3)其他補充—— 二、solidity 基礎進階《實戰NFT web3 solidity(新版本0.8.+)》

《web3 solidity0.8.版本&#xff08;持續更新新版本內容&#xff09; 基礎到實戰NFT開發》會及時更新新版本 solidity 內容&#xff0c;以及完成最終的 NFT 實戰商業項目部分。 注&#xff1a;由于是付費專欄內容&#xff0c;若有錯誤請及時聯系1_bit&#xff0c;博客鏈接&am…

Android之實現點擊布局縮小然后再放大動畫

1、需求 現在需要實現點擊View先縮小然后再放大效果 2、代碼實現 在res的anim目錄下面&#xff0c;寫anim_small.xml文件 <?xml version"1.0" encoding"utf-8"?> <set xmlns:android"http://schemas.android.com/apk/res/android"…

如何在web api中使用SignalR

說明&#xff1a; 在webapi中使用signalr&#xff0c;使用IIS 環境&#xff1a; vs2012, .net4.5 第一步&#xff1a;建web api項目 第二步&#xff1a;nuget導入signalr Install-Package Microsoft.AspNet.SignalR Install-Package Microsoft.Owin.Cors &#xff08;用于…

Directx11學習筆記【二】 將HelloWin封裝成類

我們把上一個教程的代碼封裝到一個類中來方便以后的使用。 首先新建一個空工程叫做MyHelloWin&#xff0c;添加一個main.cpp文件&#xff0c;然后新建一個類叫做MyWindow,將于窗體有關的操作封裝到里面 MyWindow.h文件 1 /***************************************************…

Badboy自動化測試工具11 導出腳本用于Jmeter并發測試

本節主要講解利用Jmeter進行并發測試和引入圖像報表 1. 在Jmeter中打開上節課&#xff08;10&#xff09;Badboy導出的在拉手網查詢KTV的腳本Lashou_Search.jmx. 2. 右擊Lashou節點&#xff0c;Add->Listener->Aggregate Graph & Graph Results 3. 對圖像報表進行配置…

ArcGIS實驗教程——實驗三十九:ArcGIS多元分類(ISO聚類分析、最大似然分類、主成分分析)案例教程

ArcGIS實驗視頻教程合集:《ArcGIS實驗教程從入門到精通》(附配套實驗數據)》 文章目錄 一、ISO聚類1. ISO聚類簡介2. ISO聚類進行非監督分類實驗操作二、最大似然分類1. 最大似然簡介2. 最大似然分類實驗案例三、主成分分析1. 主成分分析簡介2. 主成分分析實驗案例四、配套實…