• 캠퍼스북
  • LF몰 이벤트
  • 파일시티 이벤트
  • 서울좀비 이벤트
  • 탑툰 이벤트
  • 닥터피엘 이벤트
  • 아이템베이 이벤트
  • 아이템매니아 이벤트

[C언어]배열을 이용한 이진탐색트리 삽입, 삭제, 탐색 연산 프로그램

*장*
개인인증판매자스토어
최초 등록일
2007.10.15
최종 저작일
2007.10
4페이지/파일확장자 압축파일
가격 1,500원 할인쿠폰받기
다운로드
장바구니

소개글

배열을 이용하여 이진탐색트리를 구현.
삽입, 삭제, 탐색 연산 수행

1) 이진탐색트리의 삽입 연산은 현재 트리의 리프노드에서만 이루어진다. 따라서 삽입하려는 데이터의 크기 비교를 통하여 빈 노드가 있는 위치까지 찾아가 삽입이 이루어지는 방식으로 구현되어야 한다. 이번 프로그램에서는 배열로 트리가 구현되므로 인덱스 1이 루트노드에 해당하게 된다. 따라서 인덱스 1부터 탐색을 하며 왼쪽 자식의 경우 2를 곱하고, 오른쪽 자식의 경우 2를 곱한 후 1을 더하면서 저장될 위치를 찾으면 될 것이다.

2) 삽입 연산은 insert_Element, insert 함수가 담당한다. 여기서 insert는 삽입할 데이터를 받아오는 역할만 하며 실제적인 삽입 연산은 insert_Element에서 실행된다. insert_Element는 탐색함수를 이용하여 삽입할 위치를 결정하고 해당 위치에 입력된 데이터를 저장하여 준다. 이때 트리에 저장할 공간이 없는 경우 또는 이미 삽입된 레코드를 삽입하려는 경우는 삽입 실패 메시지를 띄워주고 함수를 종료한다. 삽입 연산은 insert에서 더 이상 삽입을 안 하겠다는 선택을 하기 전까지 이루어지게 된다. 삽입 할 데이터 및 삭제, 탐색 시 이용할 모든 데이터를 받아오는 역할을 담당하는 함수는 Get_Element이다.


typedef struct entry{ // 트리의 노드로 쓰일 구조체
int id;
char name[10];
char value;
}element;

element *BST[MAXSIZE+1]; // 이진탐색트리의 선언

void initSet_BST(){
int i = 0;
for(; i <= MAXSIZE; i++) { BST[i] = (element *)malloc(sizeof(element)); BST[i] = 0; }
} // 이진탐색트리 초기화

void delete_BST(){
int i = 0;
for(; i <= MAXSIZE; i++) free(BST[i]);
} // 이진탐색트리 삭제

int delete_Element(element *a); // 지정된 노드를 삭제하고 트리를 재구성하는 함수
int insert_Element(element *a); // 지정된 노드를 삭입하고 트리를 재구성하는 함수
int search_Element(element *a); // 지정된 노드를 찾아 그 위치를 반환하는 함수

void _insert(); // 삽입함수
void _delete(); // 삭제함수
void _search(); // 탐색함수
void reconstruct_BST(int i); // 트리 재구성 함수

void Get_Element(element *a); // 트리의 노드로 쓰일 정보를 받아오는 함수
void Get_String(char *strtemp); // 문자열을 받아오는 함수
int Get_intData(); // 정수를 받아오는 함수
void _strcpy(char *a, char *b); // 문자열 복사 함수
int _strcmp(char a[], char b[]); // 문자열 비교 함수
int _strlen(char a[]); // 문자열의 길이를 구하는 함수

int main()
{
int select;
initSet_BST();
while(1){
printf("======================================================n");
printf("1.INSERT 2.DELETE 3.SEARCH 4.EXITn");
printf("======================================================n");
select = Get_intData();

컴파일 실행환경

c

압축파일 내 파일목록

PL1.dsw
PL1.ncb
PL1.plg
PL1.dsp
bst.c
PL1.opt
BST.hwp
Debug/vc60.idb
Debug/vc60.pdb
Debug/bst.obj
Debug/PL1.pdb
Debug/PL1.ilk
Debug/PL1.exe
Debug/PL1.pch

참고 자료

없음

자료후기(1)

*장*
판매자 유형Bronze개인인증

주의사항

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

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

파일오류 중복자료 저작권 없음 설명과 실제 내용 불일치
파일의 다운로드가 제대로 되지 않거나 파일형식에 맞는 프로그램으로 정상 작동하지 않는 경우 다른 자료와 70% 이상 내용이 일치하는 경우 (중복임을 확인할 수 있는 근거 필요함) 인터넷의 다른 사이트, 연구기관, 학교, 서적 등의 자료를 도용한 경우 자료의 설명과 실제 자료의 내용이 일치하지 않는 경우
최근 본 자료더보기
탑툰 이벤트
[C언어]배열을 이용한 이진탐색트리 삽입, 삭제, 탐색 연산 프로그램
  • 레이어 팝업
  • 레이어 팝업
  • 레이어 팝업
  • 레이어 팝업
  • 레이어 팝업