이진 탐색 트리 질문
사랑해
질문 제목 : 이진 탐색 트리에서의 문제.
#include stdio.h
#include stdlib.h
#include windows.h
#define IS_FULL(ptr) (!(ptr))
#define IS_EMPTY(ptr)(!(ptr))
//////////////////////////////////구조체//////////////////////////////////
typedef struct node *tree_pointer;
typedef struct node{
int data;
tree_pointer left_child;
tree_pointer right_child;
};
//////////////////////////////////함수원형//////////////////////////////////
void print_tree(tree_pointer);
tree_pointer search2(tree_pointer,int);
void insert_node(tree_pointer*,int);
tree_pointer modified_search(tree_pointer, int);
tree_pointer root = NULL;
//////////////////////////////////메인함수//////////////////////////////////
void main()
{
int user;
while(1)
{
printf([삽입:1] [삭제:2번] [검색:3] [출력:4] [종료:0:]);
scanf(%d,&user);
if(user == 1)
{
printf(삽입할 데이터를 입력하십시오: );
scanf(%d,&user);
insert_node(&root,user);
}
else if(user == 2)
{
printf(삭제할 데이터를 입력하십시오: );
scanf(%d,&user);
//delet_node(&root,user);
}
else if(user == 3)
{
printf(검색할 데이터를 입력하십시오: );
scanf(%d,&user);
search2(root,user);
if(root-data){
printf(%d가 트리내에 존재합니다\n,root-data);
}
else{
printf(%d가 트리내에 존재하지 않습니다\n,user);
}
}
else if(user == 4)
{
print_tree(root);
}
else if (user == 0)
exit(1);
else
printf(잘못 입력 하셨습니다\n);
}
}
////////////////////////////////////////////////////////////////////////////
tree_pointer search2(tree_pointer tree, int key)
{
while(tree)
{
if(key == tree-data)return root;
if(key tree-data)
tree = tree-left_child;
else
tree = tree-right_child;
return NULL;
}
return NULL;
}
void insert_node(tree_pointer *node,int num)
{
tree_pointer ptr, temp = modified_search(*node, num);
if(temp || !(*node))
{
ptr=(tree_pointer)malloc(sizeof(node));
if(IS_FULL(ptr))
{
fprintf(stderr, The memory is full\n);
exit(1);
}
ptr-data = num;
ptr-left_child = ptr-right_child = NULL;
if(*node)
if(num temp-data)
temp-left_child = ptr;
else temp-right_child = ptr;
else *node = ptr;
}
}
tree_pointer modified_search(tree_pointer tree, int key)
{
while(tree)
{
if(key == tree-data)
return NULL;
else if(key tree-data)
{
if(tree-left_child == NULL)
return tree;
tree = tree-left_child;
}
else
{
if(tree-right_child == NULL)
return tree;
tree = tree-right_child;
}
}
return 0;
}
void print_tree(tree_pointer root)
{
printf(%3d\n,root-data);
printf(%3d\n,root-left_child);
printf(%3d\n,root-right_child);
}
질문 내용 : 일단 실행을 하면 에러는 없구요..[삽입:1] [삭제:2번] [검색:3] [출력:4] [종료:0:]
1번을 누르면 삽입이 되야되고 2번의 삭제 경우는 아직 함수를 만들지 않았습니다;; 검색을 하면
삽입했던 데이터를 찾아야 되고 현재의 트리상태를 출력을 해야 하는데.. 삽입을 하면
처음 삽입했던것만 적용이 되고 두번째부터 삽입한것은 아에 먹히지가 않네요..
검색역시 첫번째로 넣었던 값만 계속 뜰 뿐이고..
출력을 하면 처음값과 0 과 주소값 총 3개가 뜨네요.. -_ㅠ흐흐흙......
답보다는 간단한 힌트좀 주실수 있을까요 -_ㅠ
-
가자
휴 지난주에 끝냈지만 댓글이 늦었네요 힌트 감사합니다. 아직도 갈길이 너무 많군요..
뭔가 좀더 세부적으로 배우고 기초적인것도 부족한 부분이 있다면 바로 바로 초심으로 돌아가서 배워야 할게 많다는걸 세삼스레 느꼈습니다. 좋은말씀 다시한번 감사드립니다. -
콩알녀
일단 트리로 짜신다면 생각하기 가장 편한 방법이 재귀함수입니다. 미들값을 하나 정하신다음에 그값과 비교후 계속 왼쪽인지 오른쪽인지 판단해서 붙여주면 됩니다. 또 다른 방법은 그냥 링크드리스트로 값을 입력하시고 나중에 정렬하신다음 가운데부터 위로 끌어올려주시는 방법도 있습니다. 처음 가운데 잡으면 ㅅ 이런모양이 되겠죠 그다음 현제 가운데값빼고 왼쪽에서 가운데 오른쪽에서 가운데식으로 반복해주면 그역시 훌륭한 이진트리가 됩니다.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676182 | 숫자 순서대로 배열하는법 | 권뉴 | 2024-11-24 |
2676152 | 기본적인거 하나 질문드립니다. | 개미 | 2024-11-24 |
2676124 | 함수선언관련 질문이에요~...털썩..수정완료 (2) | 가지 | 2024-11-24 |
2676092 | C언어 책 (2) | 아서 | 2024-11-24 |
2676065 | 웹사이트 또는 메신저 등에서 원하는 텍스트를 검사하는방법?? (1) | 모든 | 2024-11-23 |
2676033 | 배열 기초연습중 발생하는 에러 ㅠㅜ... | Creative | 2024-11-23 |
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |