這是一篇遲到的部落格
找一條最廉價的最短路徑
輸入檔案第一行有兩個整數m和n,用乙個空格隔開,其中,m是頂點數,而n是邊數。接下來的n行給出所有的邊及其價值,每行有3個整數(相鄰兩個整數間有乙個空格),表示起點,終點和邊的價值。頂點最多有100個,編號在0到99之間。邊最多有1000條,其價值在0到2^15-1之間。
輸出檔案僅有一行包含乙個整數,即v0→v1的廉價最短路徑的費用。當出現有多個廉價最短路徑的情況時,它們的費用是一樣的。
4 5
0 2 2
0 3 2
0 1 10
2 1 2
3 1 2
正常最短路演算法,只不過加上乙個判斷
#include
using namespace std;
struct woc;
woc a[1001];
long long xx,yy,n,m,k,state[101],ls[101],t,head,tail,f[101],s[101];
bool v[101];
int main()
for (int i=1;i<=n;i++)
head=0;
tail=1;
state[1]=1;
v[state[1]]=true;
f[1]=0;
s[1]=0;
while (head!=tail)//spfa
}t=a[t].next;
}v[state[head]]=false;
}printf("%lld",s[2]);
}
SSLGZ 2661 廉價最短路徑
問題描述 是由一組頂點和一組邊組成的。一條邊連線兩個頂點。例如,圖1表示了乙個有4個頂點v 5條邊的圖。圖中,每條邊e是有方向的,方向從起點到終點,並且每條邊都有價值。用整數0,1,m 1可以表示乙個有m個頂點的圖。一條路徑連線了乙個點vi和另乙個點vj,其方向與經過的一系列邊的方向一致。路徑的長度...
SPFA 廉價最短路徑
圖是由一組頂點和一組邊組成的。一條邊連線兩個頂點。例如,圖1表示了乙個有4個頂點v 5條邊的圖。圖中,每條邊e是有方向的,方向從起點到終點,並且每條邊都有價值。用整數0,1,m 1可以表示乙個有m個頂點的圖。一條路徑連線了乙個點vi和另乙個點vj,其方向與經過的一系列邊的方向一致。路徑的長度是途經邊...
Floyed 廉價最短路徑
乙個圖中,在滿足最短路的前提下,求最小代價 圖是由一組頂點和一組邊組成的。一條邊連線兩個頂點。例如,圖1表示了乙個有4個頂點v 5條邊的圖。圖中,每條邊e是有方向的,方向從起點到終點,並且每條邊都有價值。用整數0,1,m 1可以表示乙個有m個頂點的圖。一條路徑連線了乙個點vi和另乙個點vj,其方向與...