BRONZE
BRONZE 등급의 판매자 자료

C 로 구현한 하노이의 탑(Tower of Hanoi)

함수의 재귀호출을 이용하는 유명한 예제인 `하노이의 탑` 을 C언어를 이용해 구현해 보았다. 프로그램 시작과 동시에 disc 의 개수를 입력받도록 하였으며 매번 disc 를 옮길때마다 출력해주도록 코딩하였다. 매번 step 마다 남은 step을 한 번만 보여줄 것인지, 모두 출력할 것인지를 묻도록 하였다. disc 의 개수가 몇개가 되어도 정확하게 결과를 보여줌을 확인하였다.
3 페이지
한컴오피스
최초등록일 2009.05.06 최종저작일 2009.05
3P 미리보기
C 로 구현한 하노이의 탑(Tower of Hanoi)
  • 미리보기

    소개

    함수의 재귀호출을 이용하는 유명한 예제인 `하노이의 탑` 을 C언어를 이용해 구현해 보았다. 프로그램 시작과 동시에 disc 의 개수를 입력받도록 하였으며 매번 disc 를 옮길때마다 출력해주도록 코딩하였다. 매번 step 마다 남은 step을 한 번만 보여줄 것인지, 모두 출력할 것인지를 묻도록 하였다. disc 의 개수가 몇개가 되어도 정확하게 결과를 보여줌을 확인하였다.

    목차

    1. 개요
    2. 프로그램 동작순서
    3. 코드첨부

    본문내용

    1. 개요
    C언어를 배울 때 재귀함수에 대해 배운다. 그 때 배우는 대표적인 예제가 하노이의 탑이다. 나는 메모리 동적할당을 이용하여 사용자가 원하는 만큼의 disc 의 개수를 입력받고 disc 들이 매 스텝마다 옮겨가는 과정을 모두 출력하여 보여주었다.

    2. 프로그램 동작 순서
    main 함수에서 disc 의 개수를 입력받고 메모리 동적할당을 이용하여 각 bar 마다 disc 개수만큼의 메모리를 만들어준다. Initialization을 해준 후에, Hanoi 함수를 호출한다. Hanoi 함수를 들여다 보면 재귀적 호출을 함을 알 수 있는데, bar 에 disc 가 하나 남았을 때는 그 디스크를 목표 bar 에 옮기는 Move 함수가 들어있다. 그 아래를 보면 맨 밑의 disc를 제외한 나머지 전부를 여분의 bar 에 옮긴후 맨 밑의 disc를 목적지 bar 로 옮기고, 다시 나머지 모든 disc를 목적지 bar에 옮기는 작업을 확인할 수 있다.

    3. 프로그램 코드

    #include<stdio.h>
    #include<stdlib.h>

    /*
    global variables.
    */
    int turn;
    int* bar[3];
    int plate_num;
    int print_mode;

    /*
    print each step.

    참고자료

    · 없음
  • 자료후기

    Ai 리뷰
    매번 새로운 인사이트를 제공해 주어 지식의 폭이 넓어지는 기분입니다. 지식판매자 덕분에 많은 것을 배우고 있습니다. 정말 추천하고 싶습니다!
    왼쪽 화살표
    오른쪽 화살표
  • 자주묻는질문의 답변을 확인해 주세요

    해피캠퍼스 FAQ 더보기

    꼭 알아주세요

    • 자료의 정보 및 내용의 진실성에 대하여 해피캠퍼스는 보증하지 않으며, 해당 정보 및 게시물 저작권과 기타 법적 책임은 자료 등록자에게 있습니다.
      자료 및 게시물 내용의 불법적 이용, 무단 전재∙배포는 금지되어 있습니다.
      저작권침해, 명예훼손 등 분쟁 요소 발견 시 고객센터의 저작권침해 신고센터를 이용해 주시기 바랍니다.
    • 해피캠퍼스는 구매자와 판매자 모두가 만족하는 서비스가 되도록 노력하고 있으며, 아래의 4가지 자료환불 조건을 꼭 확인해주시기 바랍니다.
      파일오류 중복자료 저작권 없음 설명과 실제 내용 불일치
      파일의 다운로드가 제대로 되지 않거나 파일형식에 맞는 프로그램으로 정상 작동하지 않는 경우 다른 자료와 70% 이상 내용이 일치하는 경우 (중복임을 확인할 수 있는 근거 필요함) 인터넷의 다른 사이트, 연구기관, 학교, 서적 등의 자료를 도용한 경우 자료의 설명과 실제 자료의 내용이 일치하지 않는 경우

함께 구매한 자료도 확인해 보세요!

찾으시던 자료가 아닌가요?

지금 보는 자료와 연관되어 있어요!
왼쪽 화살표
오른쪽 화살표
문서 초안을 생성해주는 EasyAI
안녕하세요. 해피캠퍼스의 방대한 자료 중에서 선별하여 당신만의 초안을 만들어주는 EasyAI 입니다.
저는 아래와 같이 작업을 도와드립니다.
- 주제만 입력하면 목차부터 본문내용까지 자동 생성해 드립니다.
- 장문의 콘텐츠를 쉽고 빠르게 작성해 드립니다.
- 스토어에서 무료 캐시를 계정별로 1회 발급 받을 수 있습니다. 지금 바로 체험해 보세요!
이런 주제들을 입력해 보세요.
- 유아에게 적합한 문학작품의 기준과 특성
- 한국인의 가치관 중에서 정신적 가치관을 이루는 것들을 문화적 문법으로 정리하고, 현대한국사회에서 일어나는 사건과 사고를 비교하여 자신의 의견으로 기술하세요
- 작별인사 독후감
해캠 AI 챗봇과 대화하기
챗봇으로 간편하게 상담해보세요.
2025년 04월 26일 토요일
AI 챗봇
안녕하세요. 해피캠퍼스 AI 챗봇입니다. 무엇이 궁금하신가요?
10:53 오전