Basic Pascal Tutorial/Chapter 4/Solution/ja

From Lazarus wiki
Jump to navigationJump to search

български (bg) English (en) français (fr) 日本語 (ja) 中文(中国大陆) (zh_CN)

4Ga - ハノイの塔の解答例 (著者: Tao Yue, 状態: 原文のまま変更なし)

(* 著者:    Tao Yue
   日付:      13 July 2000
   記述:
      ハノイの塔の解答
   Version:
      1.0 - original version
*)

program TowersofHanoi;

var
   numdiscs : integer;

(********************************************************)

procedure DoTowers (NumDiscs, OrigPeg, NewPeg, TempPeg : integer);
(* 変数の説明:
      Number of discs -- OrigPegに載っている円盤の数
      OrigPeg -- 塔の棒の数
      NewPeg -- 塔から移動させる棒のナンバー
      TempPeg -- 一時的に置いておくために使う棒のナンバー
*)

begin
   (* 最初のベースの場合を処理する -- 1つの円盤 *)
   if NumDiscs = 1 then
      writeln (OrigPeg, ' ---> ', NewPeg)
   (* 他のすべての場合を処理する *)
   else
      begin
         (* 最初に一番下の円盤以外の全てを TempPeg に移動させる。その際には NewPeg を一時保存の棒として使う *)
         DoTowers (NumDiscs-1, OrigPeg, TempPeg, NewPeg);
         (* 次に一番下の円盤を OrigPeg から NewPeg に動かす*)
         writeln (OrigPeg, ' ---> ', NewPeg);
         (* 最後に一時的に TempPeg にある円盤を NewPeg に動かす。その移動の際、OrigPeg を一時的な棒として使う *)
         DoTowers (NumDiscs-1, TempPeg, NewPeg, OrigPeg)
      end
end;

(********************************************************)


begin    (* Main *)
   write ('Please enter the number of discs in the tower ===> ');
   readln (numdiscs);
   writeln;
   DoTowers (numdiscs, 1, 3, 2)
end.     (* Main *)
previous contents next