program p_maxsi;                (* Maximum-Sum-Insertion, Thomas Klein  1999 *)
uses graph,tsp;
var anfang:stadtnr;

procedure maxsi(anfang:stadtnr;var w:weg);
 (* Maximum-Sum-Insertion mit Startpunkt anfang *)
 var m,n,i,j:stadtnr;
     mm,l:entfernung;
 begin
  w:=chr(anfang)+chr(anfang);
  while length(w)<=stadtanzahl do begin
   mm:=-maxentfernung;
   for i:=2 to length(w) do begin
    m:=ord(w[i]);
    for j:=1 to stadtanzahl do
     if pos(chr(j),w)=0 then begin
      l:=entftab[m,j]+entftab[j,anfang];
      if l>mm then begin mm:=l; n:=j; end;
     end;
   end;
   mm:=maxentfernung;
   for i:=2 to length(w) do begin
    l:=entftab[ord(w[i-1]),n]+entftab[n,ord(w[i])]
       -entftab[ord(w[i-1]),ord(w[i])];
    if l<mm then begin mm:=l; m:=i; end;
   end;
   insert(chr(n),w,m);
  end;
 end;

begin
 if tspinit('TSP: Maximum-Sum-Insertion mit Startpunktwahl','Berechnen') then
  while tspmenue([0..255]) do begin
   meldung('Startpunkt w„hlen!',green,white);
   anfang:=stadtwahl(255);
   start; maxsi(anfang,aktuell); stop;
   wegkarte(aktuell,true,brown,yellow);
   laenge_aus(aktuell); zeit_aus(true);
  end;
 closegraph;
end.
