program p_sn;                (* Start-Nachbar-Verfahren, Thomas Klein  1999 *)
uses graph,tsp;
var anfang:stadtnr;

procedure sn(anfang:stadtnr;var w:weg);
 (* Start-Nachbar mit Startpunkt anfang,
    n„chster Punkt i: Abstand(aktuell,i)/Abstand(i,anfang) min. *)
 var n,i,j:stadtnr;
     m,l:real;
 begin
  n:=anfang; w:=chr(n);
  while length(w)<stadtanzahl do begin
   m:=maxentfernung;
   for i:=1 to stadtanzahl do
    if pos(chr(i),w)=0 then begin
     l:=entftab[n,i]/entftab[i,anfang];
     if l<m then begin j:=i; m:=l; end;
    end;
   n:=j; w:=w+chr(n);
  end;
  w:=w+chr(anfang);
 end;

begin
 if tspinit('TSP: Start-Nachbar-Verfahren','Berechnen') then
  while tspmenue([0..255]) do begin
   meldung('Startpunkt w„hlen!',green,white);
   anfang:=stadtwahl(255);
   start; sn(anfang,aktuell); stop;
   wegkarte(aktuell,true,brown,yellow);
   laenge_aus(aktuell); zeit_aus(true);
  end;
 closegraph;
end.
