• 통큰쿠폰이벤트-통합

0-1 Knapsack Problem (0-1 배낭 문제) - 전체 C 코드, 입력 데이터셋 및 출력 결과 포함

김쿠크
개인인증판매자스토어
최초 등록일
2019.04.11
최종 저작일
2015.06
18페이지/ 압축파일
가격 1,000원 할인쿠폰받기
다운로드
장바구니

소개글

0-1 Knapsack Problem에 대해 세 가지 방법을 구현하고, 입력 자료에 대해 최대 이윤과 해벡터 및 수행 시간을 출력하는 프로그램을 작성하여라. 정렬 알고리즘은 최소힙(min-heap)을 사용하는 힙 정렬을 이용하여라.
(방법 1) Depth-first search with branch-and-bound
(방법 2) Breadth-first search with branch-and-bound
(방법 3) Best-fit search with branch-and-bound

< 포함 사항 >
- 0_1_knapsack.cpp (전체 코드)
- 0_1_knapsack.h (헤더 파일)
- ProgrammingReport3.hwp (보고서)
- p3data0~6.txt (입력데이터셋)
- p3data0~6.jpg (출력 결과)

목차

1. 문제 설명

2. 입출력의 예
(1) 입력 자료 형식의 예
(2) 출력 형식의 예 (각 방법에 대해)

3. 문제풀이 방법 (알고리즘)

4. 소스 코드

5. 수행 결과

6. 결과 분석 및 토의

본문내용

방법 1(depth first search with branch-and-bound)의 경우 재귀함수를 호출하여 자식 노드를 생성하는 방식으로 구현하였다. 현재 object를 include 하는 경우와 하지 않는 경우, 이렇게 두 가지로 나뉘어 각각 left child와 right child로 구분된다. 재귀 함수 호출을 위한 stack은 따로 구현하지 않았다. solution vector는 한 번만 출력하였는데, solution vector는 방법 1에서 구하여 출력하였다. 이 solution vector를 구하기 위해 현재 상태가 최대 이윤인 경우(최대 무게보다 작거나 같은 상황에서) 현재 상태를 따로 저장해두었다.
방법 2(breadth first search with branch-and-bound)의 경우 queue를 통해 노드를 생성하는 방식으로 구현하였다. 방법 1에서 stack을 사용한 것이라면 여기서는 queue를 사용한 것이다. 방법 1과 마찬가지로 현재 object를 include 하는 경우와 하지 않는 경우, 두 가지로 나뉘어 각각 left child과 right child로 구분하여 생성하였다. 재귀함수 호출 대신 단일 반복문을 사용하여 구현하였다.
방법 3(best-fit search with branch-and-bound)의 경우 priority queue를 통해 노드를 생성하는 방식으로 구현하였다. 방법 1의 stack과 방법 2의 queue 대신 priority queue를 사용하는 방식이다. 여기서 priority queue는 heap의 형태로 구현하였다. 그렇지만 heap sorting에 사용된 heap과는 달리 max heap의 형태로 구현하였다. 다른 방법들과 마찬가지로 현재 object를 include 하는 경우와 하지 않는 경우, 두 가지 각각 left child와 right child로 구분하여 생성하였다. 재귀함수를 호출하지 않는 대신 단일 반복문을 통해 구현하였다.

참고 자료

없음

압축파일 내 파일목록

0_1_knapsack.cpp
0_1_knapsack.h
input output/
input output/p3data0.JPG
input output/p3data0.txt
input output/p3data1.JPG
input output/p3data1.txt
input output/p3data2.JPG
input output/p3data2.txt
input output/p3data3.JPG
input output/p3data3.txt
input output/p3data4.JPG
input output/p3data4.txt
input output/p3data5.JPG
input output/p3data5.txt
input output/p3data6.JPG
input output/p3data6.txt
ProgrammingReport3.hwp

자료후기(1)

김쿠크
판매자 유형Bronze개인인증

주의사항

저작권 자료의 정보 및 내용의 진실성에 대하여 해피캠퍼스는 보증하지 않으며, 해당 정보 및 게시물 저작권과 기타 법적 책임은 자료 등록자에게 있습니다.
자료 및 게시물 내용의 불법적 이용, 무단 전재∙배포는 금지되어 있습니다.
저작권침해, 명예훼손 등 분쟁 요소 발견 시 고객센터의 저작권침해 신고센터를 이용해 주시기 바랍니다.
환불정책

해피캠퍼스는 구매자와 판매자 모두가 만족하는 서비스가 되도록 노력하고 있으며, 아래의 4가지 자료환불 조건을 꼭 확인해주시기 바랍니다.

파일오류 중복자료 저작권 없음 설명과 실제 내용 불일치
파일의 다운로드가 제대로 되지 않거나 파일형식에 맞는 프로그램으로 정상 작동하지 않는 경우 다른 자료와 70% 이상 내용이 일치하는 경우 (중복임을 확인할 수 있는 근거 필요함) 인터넷의 다른 사이트, 연구기관, 학교, 서적 등의 자료를 도용한 경우 자료의 설명과 실제 자료의 내용이 일치하지 않는 경우

이런 노하우도 있어요!더보기

최근 본 자료더보기
유니스터디 이벤트
0-1 Knapsack Problem (0-1 배낭 문제) - 전체 C 코드, 입력 데이터셋 및 출력 결과 포함
  • 아이템매니아 이벤트
  • 유니스터디 이벤트
AI 챗봇
2024년 09월 21일 토요일
AI 챗봇
안녕하세요. 해피캠퍼스 AI 챗봇입니다. 무엇이 궁금하신가요?
11:50 오후
문서 초안을 생성해주는 EasyAI
안녕하세요. 해피캠퍼스의 방대한 자료 중에서 선별하여 당신만의 초안을 만들어주는 EasyAI 입니다.
저는 아래와 같이 작업을 도와드립니다.
- 주제만 입력하면 목차부터 본문내용까지 자동 생성해 드립니다.
- 장문의 콘텐츠를 쉽고 빠르게 작성해 드립니다.
9월 1일에 베타기간 중 사용 가능한 무료 코인 10개를 지급해 드립니다. 지금 바로 체험해 보세요.
이런 주제들을 입력해 보세요.
- 유아에게 적합한 문학작품의 기준과 특성
- 한국인의 가치관 중에서 정신적 가치관을 이루는 것들을 문화적 문법으로 정리하고, 현대한국사회에서 일어나는 사건과 사고를 비교하여 자신의 의견으로 기술하세요
- 작별인사 독후감
방송통신대학 관련 적절한 예)
- 국내의 사물인터넷 상용화 사례를 찾아보고, 앞으로 기업에 사물인터넷이 어떤 영향을 미칠지 기술하시오
5글자 이하 주제 부적절한 예)
- 정형외과, 아동학대