Category : Recently Uploaded Files
Archive   : MSWL40.ZIP
Filename : TOWER.PAS

 
Output of file : TOWER.PAS contained in archive : MSWL40.ZIP
PROGRAM TOWER(OUTPUT);
{THIS PROGRAM SOLVES THE 5-DISK TOWER OF HANOI PROBLEM.}

PROCEDURE HANOI(NUMBER:INTEGER;FROM,ONTO,OTHER:CHAR);
{RECURSIVE PROCEDURE THAT SOLVES A SUBPROBLEM OF THE ORIGINAL PROBLEM,
MOVING SOME NUMBER OF DISKS, NOT NECESSARILY 5. TO MOVE N DISKS, IT
MUST GET THE TOPMOST N-1 OUT OF THE WAY, MOVE THE NTH TO THE TARGET
STACK, THEN MOVE THE N-1 TO THE TARGET STACK.}

PROCEDURE MOVEDISK(NUMBER:INTEGER;FROM,ONTO:CHAR);
{THIS PROCEDURE MOVES ONE SINGLE DISK. IT ASSUMES THAT THE MOVE IS
LEGAL, I.E., THE DISK IS AT THE TOP OF ITS STACK AND THE TARGET STACK
HAS NO SMALLER DISKS ALREADY. PROCEDURE HANOI IS RESPONSIBLE FOR
MAKING SURE THAT'S ALL TRUE.}

BEGIN {MOVEDISK}
WRITELN('MOVE DISK ',NUMBER:1,' FROM ',FROM,' TO ',ONTO)
END; {MOVEDISK}

BEGIN {HANOI}
IF NUMBER <> 0 THEN
BEGIN
HANOI(NUMBER-1,FROM,OTHER,ONTO);
MOVEDISK(NUMBER,FROM,ONTO);
HANOI(NUMBER-1,OTHER,ONTO,FROM)
END
END; {HANOI}

BEGIN {MAIN PROGRAM}
HANOI(5,'A','B','C')
END.


  3 Responses to “Category : Recently Uploaded Files
Archive   : MSWL40.ZIP
Filename : TOWER.PAS

  1. Very nice! Thank you for this wonderful archive. I wonder why I found it only now. Long live the BBS file archives!

  2. This is so awesome! 😀 I’d be cool if you could download an entire archive of this at once, though.

  3. But one thing that puzzles me is the “mtswslnkmcjklsdlsbdmMICROSOFT” string. There is an article about it here. It is definitely worth a read: http://www.os2museum.com/wp/mtswslnk/