Hallo,
ich möchte mit den floyd warshall algorithmus den kürzesten wege meines graphen bestimmen. dazu habe ich eine distanzmatrix programmiet(diese stimmt auch am ende) und eine vorgängermatrix(diese stimmt nciht am ende). Ich hab das ganze so realisiert:
Code:
w=y(:,3);%Kantengewicht
nn=length(w);%Anzahl der Kanten
%Adjazenzmatrix:
for i=1:nn
A(y(i,1),y(i,2))=1;
A(y(i,2),y(i,1))=1;
end
N=length(A);%Anzahl der Knoten
%Distanzmatrix:
D=ones(N,N)*999999;
for i=1:N
D(i,i)=0;
end for i=1:nn
D(y(i,1),y(i,2))=w(i);
D(y(i,2),y(i,1))=w(i);
end
%Vorgängermatrix:
V=A;
for i=1:N
V(i,i)=1;
V(i,:)=V(i,:)*i;
end
%Algorithmus:
for k=1:N
for i=1:N
for j=1:N
D(i,j)=min(D(i,j),D(i,k)+D(k,j));
if D(i,j)>D(i,k)+D(k,j)
V(i,j)=V(k,j);
end end end end
Immer wenn der weg über k kürzer ist wird k der neue vorgänger. aber da kann ja auch noch ein knoten dazwischen liegen oder?
ich glaube auch fast, dass ich einen denkfehler begehe.
ich würde mich sehr freuen, wenn jemand mein problem versteht und mit helfen kann.
grüße Dyna
Dyna
Gast
Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
Verfasst am: 10.09.2008, 16:35
Titel:
ich habs....
ich muss die distanzmatrix erst nach der if schleife neu berechnen lassen...
das man immer an sowas trivialen fast verzweifelt...
Jannik
Gast
Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
Verfasst am: 18.11.2017, 11:53
Titel: Nap
Richtiger nap hätte ich dir direkt sagen können
Einstellungen und Berechtigungen
Du kannst Beiträge in dieses Forum schreiben. Du kannst auf Beiträge in diesem Forum antworten. Du kannst deine Beiträge in diesem Forum nicht bearbeiten. Du kannst deine Beiträge in diesem Forum nicht löschen. Du kannst an Umfragen in diesem Forum nicht mitmachen. Du kannst Dateien in diesem Forum posten Du kannst Dateien in diesem Forum herunterladen
MATLAB, Simulink, Stateflow, Handle Graphics, Real-Time Workshop, SimBiology, SimHydraulics, SimEvents, and xPC TargetBox are registered trademarks and The MathWorks, the L-shaped membrane logo, and Embedded MATLAB are trademarks of The MathWorks, Inc.