Article: Q43782
Product(s): See article
Version(s): 4.00 4.00b 4.50
Operating System(s): MS-DOS
Keyword(s): ENDUSER | B_BasicCom SR# S890210-55 | mspl13_basic
Last Modified: 14-DEC-1989
The Towers of Hanoi is a problem that can be programmatically solved
through the use of recursion. Listed below are the recursive
implementations in QuickBASIC Version 4.50 and Microsoft C Version
5.10. When compiled with the compiler option giving the greatest speed
(BC /O stand-alone option), the QuickBASIC .EXE routine was roughly
40 percent slower than the C routine. No coprocessor was used, since
the program uses all integers and no floating-point calculations.
This benchmark comparison for QuickBASIC 4.50 is similar for Microsoft
QuickBASIC Versions 4.00 and 4.00b, for Microsoft BASIC Compiler
Versions 6.00 and 6.00b for MS-DOS and MS OS/2, and for Microsoft
BASIC PDS Version 7.00 for MS-DOS and MS OS/2.
The table below shows the execution speeds (in seconds) of the
recursive routine in both QuickBASIC Version 4.50 and Microsoft C
Version 5.10. The benchmark was performed on a Wyse 286, running
MS-DOS 3.30, operating at 10 megahertz. As you can see in the
following timings (based on the number of disks on the Hanoi Towers),
the QuickBASIC routine was roughly 40 percent slower than the C
routine:
Number of Disks QuickBASIC 4.50 C 5.10
1 0.0000 0.0000
2 0.0000 0.0000
3 0.0000 0.0000
4 0.0000 0.0000
5 0.0000 0.0000
6 0.0000 0.0000
7 0.0000 0.0000
8 0.0125 0.0000
9 0.0368 0.0000
10 0.0624 0.0000
11 0.1093 0.0000
12 0.1601 0.0802
13 0.3789 0.1739
14 0.8203 0.3674
15 1.5898 0.7812
16 3.1911 1.7310
17 6.4296 3.8761
18 12.796 7.2687
19 25.539 15.234
20 51.132 31.021
Code Example
REM ** QuickBASIC program:
REM Compile as follows: BC HANOI.BAS/O;
REM Link as follows: LINK HANOI.OBJ;
DEFINT A-Z
DECLARE SUB HANOI(DISKS,TOWERA(),TOWERB(),TOWERC())
CLEAR ,, 4096
DIM TOWERA(2)
DIM TOWERB(2)
DIM TOWERC(2)
PRINT
PRINT" RECURSIVE TOWERS OF HANOI"
DO
INPUT "NUMBER OF DISKS? ", DISKS
PRINT
IF DISKS<>0 THEN
TOWERA(0)=1
TOWERB(0)=2
TOWERC(0)=3
PRINT
CALL HANOI(DISKS,TOWERA(),TOWERB(),TOWERC())
END IF
LOOP UNTIL DISKS=0
END
FUNCTION WHICHTOWER$(TOWER%)
SELECT CASE TOWER%
CASE 1: WHICHTOWER$=" A "
CASE 2: WHICHTOWER$=" B "
CASE 3: WHICHTOWER$=" C "
END SELECT
END FUNCTION
SUB HANOI (DISKS,TOWERA(),TOWERB(),TOWERC())
IF DISKS=1 THEN
DESTINATION$=WHICHTOWER$(BYVAL TOWERC(0))
SOURCE$=WHICHTOWER$(BYVAL TOWERA(0))
PRINT "MOVED DISK FROM"; SOURCE$;"TO";DESTINATION$
ELSE
CALL HANOI(DISKS-1,TOWERA(),TOWERC(),TOWERB())
DESTINATION$=WHICHTOWER$(BYVAL TOWERC(0))
SOURCE$=WHICHTOWER$(BYVAL TOWERA(0))
PRINT "MOVED DISK FROM"; SOURCE$;"TO";DESTINATION$
CALL HANOI(DISKS-1,TOWERB(),TOWERA(),TOWERC())
END IF
END SUB
#include <time.h>
#include <stdio.h>
char *source=" Z ",*destination=" Z ";
void hanoi(disks,TowerA,TowerB,TowerC)
int disks;
int TowerA,TowerB,TowerC;
{
extern char *source,*destination;
if (disks == 1)
{
switch (TowerA)
{
case 1 :
source=" A \0";
break;
case 2 :
source=" B \0";
break;
case 3 :
source=" C \0";
break;
}
switch (TowerC)
{
case 1 :
destination=" A \0";
break;
case 2 :
destination=" B \0";
break;
case 3 :
destination=" C \0";
break;
}
/*printf("\nMOVED DISK FROM %s to %s",source,destination);*/
}
else
{
hanoi(disks-1,TowerA,TowerC,TowerB);
switch (TowerA)
{
case 1 :
source=" A \0";
break;
case 2 :
source=" B \0";
break;
case 3 :
source=" C \0";
break;
}
switch (TowerC)
{
case 1 :
destination=" A \0";
break;
case 2 :
destination=" B \0";
break;
case 3 :
destination=" C \0";
break;
}
/*printf("\nMOVED DISK FROM %s to %s",source,destination);*/
hanoi(disks-1,TowerB,TowerA,TowerC);
}
}
main ()
{
int TowerA=1,TowerB=2,TowerC=3,disks,thatone;
long start=01,finish=01;
clock_t clock(void);
float amnttime;
printf("number of disks? ");
scanf("%d",&disks);
while (disks!=0)
{
start=(long)clock();
hanoi(disks,TowerA,TowerB,TowerC);
finish=(long)clock();
amnttime=(float)((finish-start)/(float)CLK_TCK);
printf("\nPROGRAM TOOK %04.04f", amnttime);
printf(" SECONDS WITH %d DISKS",disks);
printf("\nnumber of disks? ");
scanf("%d",&disks);
}
fcloseall();
}