#2861 城市交易 【最大瓶頸路+貪心】

来源:https://www.cnblogs.com/rhjoi/archive/2019/02/16/10389078.html
-Advertisement-
Play Games

**【描述】**L在N個不同的城市做生意,他收到了N個不同城市的N份交易訂單。在這N個城市之間有一些低速公路,這些低速公路都有自己的一個載重上限,這限制了你在這條公路上前進的時候能夠攜帶的貨物數量。除了低速公路之外,還有些城市修了慢速鐵路站。對於修了慢速鐵路站的城市,你可以乘坐慢速火車在這些城市之間 ...


 

**【描述】**
L在N個不同的城市做生意,他收到了N個不同城市的N份交易訂單。在這N個城市之間有一些低速公路,這些低速公路都有自己的一個載重上限,這限制了你在這條公路上前進的時候能夠攜帶的貨物數量。除了低速公路之外,還有些城市修了慢速鐵路站。對於修了慢速鐵路站的城市,你可以乘坐慢速火車在這些城市之間往返而不受載重上限的限制。

L現在要按照順序來處理這N份訂單,他可以自由選擇自己的路線。這N份訂單每份訂單可能是要從客戶中買進一些貨物,或者售出一些貨物,並且有可以交易的上限存在。L希望自己在交易完最後一筆訂單之後自己不會剩下貨物,並且在整個過程中不會出現因載重限制丟棄貨物的情況(意味著你並不會每次都以最大量買入)。在滿足以上所有條件的情況下,L希望自己的交易量最大(即買入賣出都儘量多),那麼最大的交易量應該是怎樣的呢?

**【數據範圍與規定】**

對於20%的數據,N≤100,M≤200。

對於50%的數據,N≤3000,M≤6000。

對於100%的數據,N≤10^5,N-1≤M≤2*10^5,0≤Q≤N,0<|x|<10^9,保證任意兩個城市之間可以通過低速公路連通。

做法:

註意建圖的細節。

先跑最大瓶頸路(最大生成樹+lca維護兩點間最小距離), 最後處理成一條鏈貪心轉移即可(只需要輸出賣出的方案)

 

代碼:

  1 #include<bits/stdc++.h>
  2 using namespace std;
  3 #define re register
  4 #define int long long
  5 const int INF=1e14+9;
  6 const int maxm=6e5+10,maxn=2e5+10;
  7 int n,m,Q,on;
  8 struct edge{
  9 int v,nxt,w;
 10 }e[maxm];
 11 int head[maxn],cnt=0;
 12 inline void _add(int u,int v,int w){
 13 e[++cnt]=(edge){v,head[u],w};
 14 head[u]=cnt;
 15 }
 16 struct pi{
 17 int u,v,w;
 18 }p[maxm];
 19 bool cmp(pi a,pi b){
 20 return a.w>b.w;
 21 }
 22 int a1,a2,a3;
 23 int ord[maxn];
 24 bool col[maxn];
 25 int ff[maxn];
 26 int find(int u){
 27 return ff[u]==0? u:ff[u]=find(ff[u]);
 28 }
 29 inline void build(){
 30 sort(p+1,p+on+1,cmp);
 31 for(int i=1;i<=on;++i){
 32 a1=p[i].u,a2=p[i].v,a3=p[i].w;
 33 int f1=find(a1),f2=find(a2);
 34 if(f1==f2)continue;
 35 ff[f1]=f2;
 36 _add(a1,a2,a3);_add(a2,a1,a3);
 37 //if(amt==n-Q+1)break;
 38 }
 39 }
 40 int fa[maxn][50],mn[maxn][50],dep[maxn];
 41 //mn contain this now
 42 //fa start from the last one
 43 void Run(int u){
 44 for(int i=1;(1<<i)<=dep[u];++i){
 45 fa[u][i]=fa[fa[u][i-1]][i-1];
 46 mn[u][i]=min(mn[u][i-1],mn[fa[u][i-1]][i-1]);
 47 }
 48 for(int i=head[u];i;i=e[i].nxt){
 49 int v=e[i].v;
 50 if(!dep[v]){
 51 dep[v]=dep[u]+1;
 52 fa[v][0]=u;mn[v][0]=e[i].w;
 53 Run(v);
 54 }
 55 }
 56 
 57 }
 58 inline int get(int a,int b){
 59 if(dep[a]<dep[b])swap(a,b);
 60 int gap=dep[a]-dep[b];
 61 int ret=INF;
 62 for(int i=0;(1<<i)<=gap;++i){
 63 if(gap&(1<<i)){
 64 ret=min(ret,mn[a][i]);
 65 a=fa[a][i];    
 66 }
 67 }
 68 if(a==b)return ret;
 69 for(int i=18;i>=0;--i){
 70 if(fa[a][i]!=fa[b][i]){
 71 ret=min(ret,min(mn[a][i],mn[b][i]));
 72 a=fa[a][i],b=fa[b][i];
 73 }
 74 }
 75 return min(ret,min(mn[a][0],mn[b][0]));    
 76 }
 77 int limit[maxn];
 78 int f[maxn];
 79 int ans[maxn],top=0;
 80 signed main(){
 81 scanf("%lld%lld%lld",&n,&m,&Q);
 82 for(int re i=1;i<=n;++i)scanf("%lld",&ord[i]);
 83 for(int re i=1;i<=n;++i)scanf("%lld",&limit[i]);
 84 for(int re i=1;i<=m;++i){
 85 scanf("%lld%lld%lld",&a1,&a2,&a3);
 86 p[i]=(pi){a1,a2,a3};
 87 }
 88 
 89 for(int re i=1;i<=Q;++i){
 90 scanf("%lld",&a1);
 91 col[a1]=1;
 92 }
 93 //    for(int re i=1;i<=n;++i){
 94 //    p[i].u=col[p[i].u],p[i].v=col[p[i].v];
 95 //    }
 96 on=m;
 97 if(Q){
 98 for(int i=1;i<=n;++i){
 99 if(a1==i||col[i]==0)continue;
100 p[++on]=(pi){a1,i,INF};
101 }
102 }
103 build();
104 dep[1]=1;
105 //for(int i=0;i<=19;++i)mn[1][i]=1000000009;
106 Run(1);
107 //    cerr<<mn[2][0]<<endl;
108 //    for(int u=1;u<=n;++u){
109 //    for(int i=head[u];i;i=e[i].nxt){
110 //    int v=e[i].v;
111 //    cerr<<u<<" "<<v<<" "<<e[i].w<<endl;
112 //    }
113 //    }
114 f[1]=max(0ll,limit[ord[1]]);
115 if(limit[ord[1]]<0)ans[++top]=0;
116 for(int re i=2;i<=n;++i){
117 int u=ord[i],l=get(u,ord[i-1]);
118 //    cerr<<f[u]<<endl;
119 //    cerr<<" u= "<<u<<" l= "<<l<<" limit= "<<limit[u]<<endl;
120 int k=min(f[i-1],l);
121 f[i]=max(0ll,k+limit[u]);
122 if(limit[u]<0)ans[++top]=min(k,-limit[u]);
123 }
124 //    for(int i=1;i<=n;++i)cerr<<limit[i]<<endl;
125 for(int re i=1;i<=top;++i)printf("%lld\n",ans[i]);
126 return 0;
127 }

 


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

-Advertisement-
Play Games
更多相關文章
  • 1.概述 jupyter記事本是一個基於Web的前端,被分成單個的代碼塊或單元。根據需要,單元可以單獨運行,也可以一次全部運行。這使得我們可以運行某個場景,看到輸出結果,然後回到代碼,根據輸出結果對代碼做出相應的調整(說白了就是可以直接在瀏覽器中編寫Python程式,然後執行程式並輸出結果,是不是感 ...
  • 開始 Feign在Spring Cloud體系中被整合進來作為web service客戶端,使用HTTP請求遠程服務時能就像調用本地方法,可見在未來一段時間內,大多數Spring Cloud架構的微服務之間調用都會使用Feign來完成。 所以準備完整解讀一遍Feign的源碼,讀源碼,我個人覺得一方面 ...
  • 生產環境中,存在需要等待多個線程都達到某種狀態後,才繼續運行的情景。併發工具CyclicBarrier就能夠完成這種功能。本篇從源碼方面,簡要分析CyclicBarrier的實現原理。 使用示例 執行結果如下: 可以看到線程1,2,3在同一個時間結束。 源碼分析 主要成員: CyclicBarrie ...
  • 使用Python遠程連接並操作InfluxDB資料庫 by:授客 QQ:1033553122 實踐環境 Python 3.4.0 CentOS 6 64位(內核版本2.6.32-642.el6.x86_64) influxdb-1.5.2.x86_64.rpm 網盤下載地址: https://pan ...
  • 先上結論:run只是Thread裡面的一個普通方法,start是啟動線程的方法。何以見得呢?可以執行下麵的代碼看看run和start的區別: 執行結果: 由此可以看到子線程是由start來啟動的,裡面調用了run,所以列印出來的是子線程的name。 另外也可以從start方法的底層代碼看到,首先進入 ...
  • 本篇和大家分享的是一個清除過期日誌的python腳本,年後第二篇希望對大家有幫助; 該python腳本創建的由來 代碼及分析 crontab定時任務 該python腳本創建的由來 此由來,是在過年假期時突然被反饋告警伺服器磁碟空間占用比例增大,當時通過df等命令定位到,是使用了某個開源任務調度框架日 ...
  • 導語: PEP(Python增強提案)幾乎是 Python 社區中最重要的文檔,它們提供了公告信息、指導流程、新功能的設計及使用說明等內容。對於學習者來說,PEP 是非常值得一讀的第一手材料,學習中遇到的大部分難題,都能在 PEP 中找到答案或者解決思路。 我翻譯了幾篇 PEP,這麼做的目的一方面是 ...
  • c語言知識點總結(可能不全) include // 頭文件 int main(void) //主函數 { int n; //定義變數,';'代表語句結束 scanf("%d", $n); //$是取地址運算符 printf("%d\n",n); // '\n'為換行符 return 0: } int ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...