/*
하노이의 탑
http://ko.wikipedia.org/wiki/%ED%95%98%EB%85%B8%EC%9D%B4%EC%9D%98_%ED%83%91
1. 한번에 하나만 이동.(모든 원반을 마지막 기둥으로.)
2. 작은원반 위로 큰 원반을 이동할 수 없다.
3. 가장위의 원반만 이동가능.
알고리즘
1. 기둥 1에서 N-1개의 원반을 기둥 2로 옮긴다
2. 기둥 1에서 1개의 원반을 기둥 3으로 옮긴다.
3. 기둥 2에서 N-1개의 원반을 기둥 3으로 옮긴다.
from 기둥에서 to기둥으로 by기둥을 이용하여 옮기기
from : 이동할 기둥
to : 이동되어질 기둥
hanoi(원반수, 이동할 기둥, 나머지기둥, 이동되어질 기둥)
*/
function move($from, $to) {
printf("<br />Move from %d to %d", $from, $to);
}
function hanoi($n, $from, $by, $to) {
if ($n == 1)
move($from, $to);
else {
hanoi($n-1, $from, $to, $by); // 1
move($from, $to); // 2
hanoi($n-1, $by, $from, $to); // 3
}
}
$height = 3;
printf("Height of HANOI tower is %d <br />",$height);
hanoi($height, 1, 2, 3);
/* output
Height of HANOI tower is 3
Move from 1 to 3
Move from 1 to 2
Move from 3 to 2
Move from 1 to 3
Move from 2 to 1
Move from 2 to 3
Move from 1 to 3
*/
게시판 목록
팁게시판
디자인과 관련된 유용한 정보를 공유하세요.
질문은 상단의 QA에서 해주시기 바랍니다.
질문은 상단의 QA에서 해주시기 바랍니다.
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 5502 | 11년 전 | 3861 | ||
| 5501 | 11년 전 | 1143 | ||
| 5500 |
잘살아보자
|
11년 전 | 907 | |
| 5499 |
kiplayer
|
11년 전 | 7437 | |
| 5498 |
잘살아보자
|
11년 전 | 2312 | |
| 5497 |
잘살아보자
|
11년 전 | 1132 | |
| 5496 |
잘살아보자
|
11년 전 | 1172 | |
| 5495 |
잘살아보자
|
11년 전 | 963 | |
| 5494 |
잘살아보자
|
11년 전 | 4555 | |
| 5493 |
잘살아보자
|
11년 전 | 678 | |
| 5492 |
잘살아보자
|
11년 전 | 5238 | |
| 5491 |
잘살아보자
|
11년 전 | 3378 | |
| 5490 | 11년 전 | 1190 | ||
| 5489 |
|
11년 전 | 3278 | |
| 5488 |
잘살아보자
|
11년 전 | 2822 | |
| 5487 |
잘살아보자
|
11년 전 | 2199 | |
| 5486 |
잘살아보자
|
11년 전 | 1440 | |
| 5485 |
잘살아보자
|
11년 전 | 1451 | |
| 5484 |
잘살아보자
|
11년 전 | 2333 | |
| 5483 |
잘살아보자
|
11년 전 | 3243 | |
| 5482 |
잘살아보자
|
11년 전 | 1132 | |
| 5481 |
잘살아보자
|
11년 전 | 738 | |
| 5480 |
잘살아보자
|
11년 전 | 1363 | |
| 5479 |
잘살아보자
|
11년 전 | 678 | |
| 5478 |
잘살아보자
|
11년 전 | 1257 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기