AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Problem Pfeildaten für dijkstra (random) erstellen
Thema durchsuchen
Ansicht
Themen-Optionen

Problem Pfeildaten für dijkstra (random) erstellen

Ein Thema von pagan1900 · begonnen am 5. Jun 2006
Antwort Antwort
pagan1900

Registriert seit: 27. Mär 2006
25 Beiträge
 
#1

Problem Pfeildaten für dijkstra (random) erstellen

  Alt 5. Jun 2006, 11:36
Ich möchte aus vereinfachungsgründen das das Programm
einen digraphen erstellt für mein programm

wie ihr seht, hab ich Anf,Ende eines jeden pfeils und die kosten
per random bestimmt.
Ich habe bisher verhindert, das Anfangsknoten,Endknoten und die kostenwerte NICHT null werden können
(sonst hätte ich probleme beim zeichnen! besonders was ANF,Ende angeht!, die ja die punkte für die pfeile darstellen)
so weit so gut!

NUR ich muss jetzt und da hab ich das problem
verhindern das 2x oder mehrmals der selbe"pfeil" abgespeichert wird!
Würde es nur ums zeichnen gehen währe es ja kein problem, dann würde das programm einfach denselben übermahlen!
Nur das problem aber ist verherend, wenn mann mit solchen daten den Dijkstra berechnen soll!

wist ihr eine lösung?

ein beispiel für das problem:

Anf [1,2.4,1]
Ende [2,1,3,2]
Kosten[5,6,2,1]

Wie ihr seht kommt Pfeil (1->2) 2x vor und dann noch mit unterschidlichen Kosten, dieses muss ich verhindern,
also wenn das auftritt so solange
dieses erstellen bis

Anf [1,2.4,5]
Ende [2,1,3,2]
Kosten[5,6,2,1]

alle pfeile unterschidlich sind.

Delphi-Quellcode:
//anf,Ende,Kosten sind vom typ: TPfeil=Array[1..max_m] of integer;
 function anf_bestimmen:word;
  var local:word;
  begin
   repeat
     local:=random(n+1);
   until local >0;
   result:=local;
  end;

 function ende_bestimmen:word;
  var local:word;
  begin
   repeat
     local:=random(n+1);
   until local >0;
   result:=local;
  end;

 procedure a_b_vergleich(var deranfang,dasEnde:word);
  var local_a,local_b:word;
  begin
    repeat
      local_a:=anf_bestimmen;
      local_b:=ende_bestimmen;
    until local_a<>local_b;
    derAnfang:=local_a;
    dasEnde:=local_b;
  end;

 procedure a_b_Pfeilnur1mal(a,b:TPfeil;var a1,b1:word);
  var derAnfang,dasEnde:word;
      locali:integer;
      tempa,tempb:word;
  begin
   repeat
    for locali:= 1 to m do
     begin
       a_b_vergleich(deranfang,dasEnde);
       if ((derAnfang <>a[locali]) and (dasEnde <> b[locali])) or
         ((dasEnde <> a[locali])and(derAnfang <> b[locali]))then
        begin tempa:=derAnfang;
               tempb:=dasEnde; end;
     end;
   until ((derAnfang <>a[locali]) and (dasEnde <> b[locali])) or ((dasEnde <>
         a[locali])and(derAnfang <> b[locali]));
    a1:=tempa;
    b1:=tempb;
  end;
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 20:35 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz