BRONZE
BRONZE 등급의 판매자 자료

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

배열을 이용하여 이진탐색트리를 구현. 삽입, 삭제, 탐색 연산 수행 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();
4 페이지
압축파일
최초등록일 2007.10.15 최종저작일 2007.10
[C언어]배열을 이용한 이진탐색트리 삽입, 삭제, 탐색 연산 프로그램
  • 미리보기

    소개

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

    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

    참고자료

    · 없음
  • 자료후기

      Ai 리뷰
      지식판매자의 이 자료 덕분에 ,복잡했던 과제를 체계적으로 정리하고, 실질적인 결과를 얻을 수 있었습니다. 완벽한 자료였습니다. 매우 추천합니다.
    • 자주묻는질문의 답변을 확인해 주세요

      해피캠퍼스 FAQ 더보기

      꼭 알아주세요

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

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

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