• 통큰쿠폰이벤트-통합

[자료구조]자료구조 Binomial Heap 설계 / 실습 레포트

*태*
최초 등록일
2006.07.26
최종 저작일
2005.12
26페이지/ 압축파일
가격 1,000원 할인쿠폰받기
다운로드
장바구니

소개글

본 프로그램은 동적 메모리 할당과 해제를 담당하는 메모리 관리 시스템을 구현한다.
파일에서 메모리의 할당 및 해제에 관한 정보를 읽어들여 할당된 메모리는 Linked List 구조를 이용하고, 비할당된 메모리는 Linked List와 Binomial Heap의 이중구조를 이용하여 관리하도록 하였다. 메모리가 할당되기 위해서는 비할당된 메모리 중 가장 큰 메모리를 먼저 찾아서 그 메모리에 할당이 될 수 있는지 여부를 판단한다.
만약 최대 비할당 메모리에 삽입될 수 없는 크기라면 남아있는 비할당 메모리의 총 크기를 살펴보고, 만약 삽입될 수 있을 크기가 남아있다면 남아있는 비할당 메모리들을 Coalescing하게 된다. 그 후 다시 삽입을 시도하게 되며 Coalescing 했음에도 최대 비할당 메모리의 크기가 삽입될 메모리보다 작으면 할당이 실패한다.
메모리 삽입이 성공하게 되면 할당된 메모리는 각각의 index를 가지게 되면 메모리 해제는 해당 index를 가지고 Linked List 내에서 메모리를 찾아서 해제하게 되고, 해제된 메모리는 비할당 메모리가 됨으로써 비할당 메모리 Linked List와 Binomial Heap에 삽입되게 된다.

목차

1. Instruction
1.1 overall descriptioin
1.2 requirements
1.3 sample input/output

2. Overall System Class Design
2.1 Relationships between classes
2.2 Present class ADTs

3. Data Structure Diagram

4. Algorithm Specfication
4.1 Pseudocodes
4.2 Performance Evaluation

5. Discussion and Conclusion

본문내용

본 프로그램을 구현하기 위해서는 Linked List와 Binomial Heap 구조에 대한 이해가 필요하다. 다음은 프로그램을 구현하기 위하여 사용되는 구조에 대한 설명이다.
할당된 메모리 및 비할당된 메모리를 주소순으로 연결하기 위해선 linked list 구조를 사용하여야 하는데, 연결구조는 아래 그림과 같다.


메모리를 주소 순으로 연결함으로써 출력 제한사항에 맞게 구성하고, 또한 메모리 해제시 리스트를 순회하면서 해당 index에 맞는 노드를 손쉽게 검색할 수 있으며, coalescing 시 메모리가 주소순으로 연결되어 있으므로써, 주소가 연결된 메모리 블록을 쉽게 찾아낼 수 있다.
비할당된 메모리는 linked list뿐만 아니라 binomial heap에도 연결되어 있는데, 이는 priority queue 구조인 binomial heap을 이용함으로써 비할당된 메모리 중 최대 크기의 메모리를 쉽게 찾아낼 수 있기 때문이다. 본 프로그램에서 사용하는 메모리 할당 방식은 worst-fit 방식인데 이는 비할당된 메모리 중에서 가장 큰 메모리에 새로운 메모리를 할당하는 방식으로 binomial heap구조를 사용하여 구현할 수가 있다.

5. Discussion and Conclusion

이번 과제는 동적 메모리 할당과 해제를 담당하는 메모리 관리 시스템을 시뮬레이션 한 프로그램을 구성하기 위하여 Binomial Heap 구조를 사용하여 주어진 입력 파일에 따라서 메모리를 할당 및 해제하고 기존 메모리 블록으로 할당이 불가하면 남은 메모리를 Coalescing하여 다시 할당 시도를 하고, 그래도 할당이 되지 않으면 Fail Count를 증가하였다.

Binomial Heap의 노드들은 이중연결구조를 가지도록 구성하여서, Binomial Heap에서는 비할당 메모리의 크기 순서대로, Linked List에서는 메모리 주소 순서대로 노드를 배열하여 비할당 메모리 삽입 및 삭제시 Binomial Heap과 Linked List에서 동시에 삽입과 삭제를 수행하였다.

메모리 할당을 시도할 때 비할당 메모리 중 가장 큰 메모리보다 할당할 메모리가 크고, 남아있는 비할당 메모리의 총 size보다 작으면 Coalescing을 실시하게 되는데, 이 때 Binomial Heap의 모든 노드를 삭제 후 Linked List에서 이어진 메모리 블록을 찾아서 병합하게 된다. 하지만 가령 비할당 메모리 블록 10, 30, 40, 50이 남아있고 여기서 30과 40만이 이어진 메모리라면 실제적으로 Binomial Heap에서는 30까지의 메모리만 삭제 후 Linked List에서 병합과정을 실시하면 되는데 불필요한 메모리까지 전부 삭제함으로써 코드 상으로는 복잡함이 줄어들었지만 불필요한 실행시간이 소요되었다.

참고 자료

없음

압축파일 내 파일목록

2000120007_v1.0_설계 레포트(Assignment3).doc
2000120007_v1.0_실습 레포트(Assignment3).doc
*태*
판매자 유형Bronze개인

주의사항

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

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

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

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

최근 본 자료더보기
유니스터디 이벤트
[자료구조]자료구조 Binomial Heap 설계 / 실습 레포트
  • 유니스터디 이벤트
AI 챗봇
2024년 10월 01일 화요일
AI 챗봇
안녕하세요. 해피캠퍼스 AI 챗봇입니다. 무엇이 궁금하신가요?
8:30 오전
문서 초안을 생성해주는 EasyAI
안녕하세요. 해피캠퍼스의 방대한 자료 중에서 선별하여 당신만의 초안을 만들어주는 EasyAI 입니다.
저는 아래와 같이 작업을 도와드립니다.
- 주제만 입력하면 목차부터 본문내용까지 자동 생성해 드립니다.
- 장문의 콘텐츠를 쉽고 빠르게 작성해 드립니다.
이런 주제들을 입력해 보세요.
- 유아에게 적합한 문학작품의 기준과 특성
- 한국인의 가치관 중에서 정신적 가치관을 이루는 것들을 문화적 문법으로 정리하고, 현대한국사회에서 일어나는 사건과 사고를 비교하여 자신의 의견으로 기술하세요
- 작별인사 독후감