洛谷 P1807 最大路

2021-08-16 19:26:14 字數 704 閱讀 1510

這是一道拓撲的水題,emmm

求圖中的最長路

原題戳顯然可以用最短路寫,顯然,也可以用拓撲排序寫(top是正宗!)

這裡只給出拓撲排序的做法

因為是求從1到n的最大路,所以只有1能到的點才能更新,所以需要乙個標記陣列,儲存被誰更新,被1更新過就可以去更新其他點

乙個點的最大路=max

**如下

//by acer.mo

#include#include#include#include#include#include#includeusing namespace std;

const int m=500500;

int ind[m]=;//入度

int maxa[m]=;

int n,m,i,j;

struct edge

;//存圖

int bj[m]=;//標記(2333逃

vectorg[m];

int topsort()

if (ind[g[u][i].to]==0)

q.push(g[u][i].to);}}

return tot;

}int main()

maxa[n]=-1;bj[1]=1;//n點到不了即為-1;

topsort();

cout

}

洛谷 P1807最長路

設g為有n個頂點的有向無環圖,g中各頂點的編號為1到n,且當為g中的一條邊時有i j。設w i,j 為邊的長度,請設計演算法,計算圖g中 1,n 間的最長路徑。輸入格式 輸入檔案longest.in的第一行有兩個整數n和m,表示有n個頂點和m條邊,接下來m行中每行輸入3個整數a,b,v 表示從a點到...

洛谷 P1807 最長路(拓撲排序)

題目大意 n個頂點的帶權有向無環圖,邊權可能為負值,求1到n的最長路,無法到達則輸出 1思路 拓撲排序,直接先將入度為0的入隊,定義dis陣列,先全部設定成乙個極小值,dis i 為i號頂點到1的距離,然後拓撲排序過程中更新dis,若最後dis n 仍為極小值輸出 1,否則輸出dis n inclu...

洛谷P1807 拓撲排序 染色 最短路思想

題目鏈結 p1807 這道題的最簡單的解法應該是將初始給的權值全部取負,然後對給定的圖跑任意乙個最短路的板子,將得到的 最短路長度 再取負得到的就是最終的答案 但是因為在學習拓撲排序,就跟著大佬的拓撲思路寫了一遍拓撲的解,感覺還是有一些收穫的 include include include incl...