BRONZE
BRONZE 등급의 판매자 자료

stack을 응용한 미로찾기 구현 (알고리즘, 소스코드, 실행화면)

본 과제에서는 stack을 응용한 미로찾기를 구현하여 보았습니다. class Bag을 이용하여 stack.h 코드를 작성한 후 실질적인 미로찾기 프로그램을 작성하였으며 자세한 미로찾기 알고리즘 설명 및 소스코드, 실행화면을 담고 있습니다. 우선 기본적으로 좌측과 같은 미로가 있다고 했을 때 갈수 있는 길은 0으로 표기하고 갈수 없는 벽은 1로 표시하는 배열을 사용하였습니다. 처음 시작과 출구의 경우 0으로 세팅하였으며 이러한 모든 맵은 프로그램 실행 시 항상 랜덤으로 나올 수 있도록 램덤함수를 사용 하여 0과 1이 랜덤하게 출력되게 하였습니다. 실질적으로 미로를 찾는 과정은 크게 3가지로 구성되어 있습니다. 첫 번째, 현재 위치에서 인접한 위치 중 갈수 있는 길이 있는지 확인하는 과정, 두 번째, 길이 있다고 하였을때 이동하는 과정, 그리고 마지막으로, 길이 없을 때 다시 돌아나오는 과정이 있습니다. 각 과정에 대한 세부적인 알고리즘역시 레포트에 자세하게 구현되 있습니다.
10 페이지
한컴오피스
최초등록일 2008.08.22 최종저작일 2008.05
10P 미리보기
stack을 응용한 미로찾기 구현 (알고리즘, 소스코드, 실행화면)
  • 미리보기

    소개

    본 과제에서는 stack을 응용한 미로찾기를 구현하여 보았습니다. class Bag을 이용하여 stack.h 코드를 작성한 후 실질적인 미로찾기 프로그램을 작성하였으며 자세한 미로찾기 알고리즘 설명 및 소스코드, 실행화면을 담고 있습니다.
    우선 기본적으로 좌측과 같은 미로가 있다고 했을 때 갈수 있는 길은 0으로 표기하고 갈수 없는 벽은 1로 표시하는 배열을 사용하였습니다.
    처음 시작과 출구의 경우 0으로 세팅하였으며 이러한 모든 맵은 프로그램 실행 시 항상 랜덤으로 나올 수 있도록 램덤함수를 사용 하여 0과 1이 랜덤하게 출력되게 하였습니다.
    실질적으로 미로를 찾는 과정은 크게 3가지로 구성되어 있습니다. 첫 번째, 현재 위치에서 인접한 위치 중 갈수 있는 길이 있는지 확인하는 과정, 두 번째, 길이 있다고 하였을때 이동하는 과정, 그리고 마지막으로, 길이 없을 때 다시 돌아나오는 과정이 있습니다. 각 과정에 대한 세부적인 알고리즘역시 레포트에 자세하게 구현되 있습니다.

    목차

    1. 프로그램 설명
    1.1 맵 만들기
    1.2 길 찾기

    2. 프로그램 소스코드
    2.1 stack.h
    2.2 themaze.cpp

    3. 실행화면
    3.1 길을 찾았을 경우
    3.2 길이 없을 경우

    본문내용

    ...
    두번째 확인 결과 길이 있을 경우. 전진!
    위의 첫 번째 과정에서 길이 있다고 판명되었을 경우에는 아래 3가지 순서로 전진과정이 실행되게 됩니다.
    ① 현재위치를 stack에 push함
    ② 목적지로 이동함 (현재위치를 새위치로 업데이트)
    ③ 새로이동한 위치를 “2”로 표시
    따라서 위와 같은 과정으로 미로찾기가 진행되었을 경우 입구에서 출구까지의 찾은 길은 2로 표시되게 됩니다.

    세 번째, 확인 결과 길이 없을 경우. 후진!
    위의 첫 번째 과정에서 길이 없다고 판명되었을 경우에는 아래 순서로 후진과정이 실행되게 됩니다.
    ① stack에서 이전위치를 pop함
    ② 만약 stack이 Empty이면 길이 없는 걸로 판명되어 미로찾기가 끝남.
    ③ stack에 data가 있다면 현재위치를 “3”으로 표시
    ④ 이전위치로 이동 (현재위치를 이전위치로 업데이트)
    위와 같은 과정으로 미로 찾기가 진행되었을 경우 잘못들어간 길은 3으로 표시되게 됩니다.
    ...

    void main(){

    int maze[12][12];


    srand(time(NULL));

    for(int i=0;i<12;i++){
    maze[0][i] = 1;
    maze[11][i] = 1;
    maze[i][0] = 1;
    maze[i][11] = 1;
    }

    for(int i=1;i<11;i++){
    for(int j=1;j<11;j++){
    int temp;
    temp = rand()%5;
    if(temp==0||temp==1||temp==2)
    maze[i][j] = 1;
    else
    maze[i][j] = 0;
    }
    }
    maze[1][1] = maze[10][10] = 0;
    ...

    참고자료

    · 없음
  • 자료후기

      Ai 리뷰
      지식판매자의 자료는 항상 최신 정보를 반영하고 있어 믿을 수 있습니다. 특히, 각 주제에 대한 깊이 있는 분석과 명확한 설명 덕분에 복잡한 개념도 쉽게 이해할 수 있었습니다. 여러분에게도 강력히 추천합니다!
    • 자주묻는질문의 답변을 확인해 주세요

      해피캠퍼스 FAQ 더보기

      꼭 알아주세요

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

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

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