BRONZE
BRONZE 등급의 판매자 자료

데이터 구조 - 최단거리 검색/탐색

최단거리를 탐색하는 프로그램을 제작하는 데이터 구조 자료입니다. 레포트 내용과 소스까지 전부 포함하였습니다.
11 페이지
한컴오피스
최초등록일 2011.09.30 최종저작일 2010.09
11P 미리보기
데이터 구조 - 최단거리 검색/탐색
  • 미리보기

    소개

    최단거리를 탐색하는 프로그램을 제작하는 데이터 구조 자료입니다.

    레포트 내용과 소스까지 전부 포함하였습니다.

    목차

    1. 문제 제기
    2. 문제 분석
    1) 그래프의 저장
    2) 최단거리(저번 과제의 비용 알고리즘 이용시 -> 최소비용)의 계산
    3) 최소비용의 출력
    3. 문제 해결
    4. 결과 화면
    5. 느낀점

    본문내용

    데이터 구조
    <최단경로 탐색>
    1. 문제 제기
    그래프를 저장하고, 한 정점으로부터 다른 정점으로까지의 최단거리를 구하여라
    2. 문제 분석
    1) 그래프의 저장
    그래프의 저장은 저번과제에서 나왔던 인접행렬로 저장하였다. 인접리스트를 쓰지 않은 이유는 인접리스트에서 지정된 좌표의 값을 찾으려면 탐색을 해야 하고, 그 비용이 공간의 이점을 훨씬 뛰어넘기 때문이다. 저장의 방법은 저번 과제와 동일 하므로, 더 설명하지 않겠다.
    2) 최단거리(저번 과제의 비용 알고리즘 이용시 -> 최소비용)의 계산
    최소비용의 계산에 쓰이는 기본적인 변수는 다음과 같다.
    * 각 정점의 최소경로를 통한 비용을 저장할 double형 변수
    * 각 정점의 최소경로를 저장할 int형 포인터
    * 최소경로에 인접해있는 정점을 저장할 int형 배열
    위에서 최소경로와 비용은 Node라는 클래스의 private로 선언하였다. 처음에 최소비용 계산 함수에서 class 맴버 변수로 선언된 Node 객체 포인터를 그래프의 크기만큼 동적 할당해준다. 예를 들어 이 소스 코드에서는 Node *head 라고 맴버 변수를 선언해 주었고, 이 맴버 변수를 head = new Node[size] 이렇게 동적 할당을 한 것이다. 그 후 이 동적 할당된 Node들의 private을 초기화 해주는데, 최소경로를 저장할 int형 포인터는 그래프의 크기만큼 배열로 동적 할당 해주고, double형 변수로 선언한 비용은 -1로 초기화 해준다. 여기서 double형을 쓴 이유는, 배열에서 쓰인 각각의 연결비용이 int형으로 저장되어서 float형일 경우는 데이터 손실이 일어나기 때문이다. 이렇게 각각 초기화가 끝나면, 최소 비용을 구할 기준 정점을 입력 받는다. 그 입력을 받은 후에는 다음과 같은 과정이 있다.
    * 정점의 저장 Node에 각각의 값을 저장한다. 비용은 0, 경로는 정점(숫자)를 스택에 넣는다.
    * Loop를 통해 정점에 연결된 다른 정점 중에서 최소 비용을 가진 정점을 찾는다.
    * 최소비용이 아닐 경우, 함수 내부의 스택에 넣는다.
    * 위의 3과정이 끝나면, 최소 비용의 정점 1개와 나머지 정점들이 스택에 넣어져 있는 상태가 된다.
    * 최소 비용의 정점에 연결되어있는, 기준 정점을 제외한 모든 정점을 스택에 넣는다.
    * 최소 비용 정점의 저장 Node에 비용과 경로를 저장한다.
    이렇게 연산 과정이 끝나면, 사용자가 지정한 정점과 최소비용의 다른 정점이 무엇인지 알 수 있게 되고, 이 두 정점의 인접정점들은 스택에 저장되어있다. 그 이후의 알고리즘은 다음과 같다.

    참고자료

    · 없음
  • 자료후기

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

      해피캠퍼스 FAQ 더보기

      꼭 알아주세요

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

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

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

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