하노이탑 재귀 과정 좀 설명해주실분
물병자리
질문 제목 : 하노이탑재귀함수..알고리즘질문 내용 :
#include stdio.h
int main()
{
int n;
printf(원판을 a봉에서 c봉으로 모두 옮겨보세요.\n);
printf(원판 갯수를 입력하세요 : );
scanf(%d,&n);
printf(%d개의 원판은 a봉에 있습니다.\n,n);
bong(n,a봉,b봉,c봉);
return 0;
}
int bong(int n,int abong,int bbong,int cbong)
{
if(n==1)
{
printf(%d는 %s - %s 이동\n,n,abong,cbong);
}
else
{
bong(n-1,abong,cbong,bbong); //n-1개를 c를 이용해서 b로 옮긴다고 하네요.
printf(%d는 %s - %s 이동\n,n,abong,cbong); //n을 c로 스트레이트로 옮기고
bong(n-1,bbong,abong,cbong); // 다시 b를 a를 이용해 c로 옮기고
}
}
주석문으로 써서 그거에대해 그냥 보이는대로는 이해가 되는데
제가 묻고자 하는게
예를 들어서 n=3을 넣엇을때 그 과정에 쭈욱 어떻게 나열되는지 설명을 원해요.
n=2를 넣고 하는거랑 n=3을 넣고 하는거랑 완전히 개념이 다르네요
-
늘빈
int bong(int n, char *Abong, char *Bbong, char *Cbong);
함수는 n 개의 원반을 Abong에서 Bbong을 이용해 Cblong으로 옮기는 함수입니다.
이 함수를 추적하지 마시고, 컴파일러 회사에서 완벽하고 만들어 주었다고 생각하고 믿으세요.
재귀호출을 추적하면 피곤합니다.
bong(3,\A\
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692230 | 하노이탑 질문입니다. (1) | 미쁘다 | 2025-04-21 |
2692210 | 정보 올림피아드 문제인데.. 풀이 과정이 궁금합니다.(재귀함수) (5) | 물티슈 | 2025-04-20 |
2692144 | C언어와 리눅스에 대한 질문입니다. | 싴흐한세여니 | 2025-04-20 |
2692114 | 컨텍스트 스위칭하는데 걸리는 시간 측정.. | YourWay | 2025-04-19 |
2692086 | 간접참조 연산자, 증감연산자 질문이용! (2) | 블랙캣 | 2025-04-19 |
2692056 | 주석좀 달아주세요. 몇개적엇는데 몇개만달아주세요. (2) | DevilsTears | 2025-04-19 |
2691978 | 진수 쉽게 이해하는법... (3) | 지지않는 | 2025-04-18 |
2691949 | getchar() 한 문자를 입력받는 함수 질문 | 채꽃 | 2025-04-18 |
2691919 | 배열 정렬 및 합치기 질문입니다. | 사과 | 2025-04-18 |
2691845 | c언어왕초보 질문이 있습니다........ | 루나 | 2025-04-17 |
2691815 | void add(int num); 함수... (4) | 살랑살랑 | 2025-04-17 |
2691756 | 명령 프롬프트 스크롤바가 없어요 | 두메꽃 | 2025-04-16 |
2691725 | 자료구조에 관련해서 질문이 있어 글을 올립니다. | 누리알찬 | 2025-04-16 |
2691697 | if 문에서 구조체 배열에 저장되있던 문자열 검사하는 법 ? (2) | 민트맛사탕 | 2025-04-16 |
2691678 | C언어 함수 질문이요~!!! | 연보라 | 2025-04-15 |
2691650 | 반복문 | 돋가이 | 2025-04-15 |
2691618 | 링크드리스트 개념 질문이예요 (3) | 맨마루 | 2025-04-15 |
2691592 | 동적할당 이용 배열선언 질문입니다.ㅠㅠ (3) | 허리달 | 2025-04-15 |
2691542 | /=의 용도를 알려주세요 ㅠㅠ! (2) | 아라 | 2025-04-14 |
2691510 | sizeof 연산자 질문입니다 (2) | 종달 | 2025-04-14 |