이진 탐색 트리 질문
사랑해
질문 제목 : 이진 탐색 트리에서의 문제.
#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개가 뜨네요.. -_ㅠ흐흐흙......
답보다는 간단한 힌트좀 주실수 있을까요 -_ㅠ
-
가자
휴 지난주에 끝냈지만 댓글이 늦었네요 힌트 감사합니다. 아직도 갈길이 너무 많군요..
뭔가 좀더 세부적으로 배우고 기초적인것도 부족한 부분이 있다면 바로 바로 초심으로 돌아가서 배워야 할게 많다는걸 세삼스레 느꼈습니다. 좋은말씀 다시한번 감사드립니다. -
콩알녀
일단 트리로 짜신다면 생각하기 가장 편한 방법이 재귀함수입니다. 미들값을 하나 정하신다음에 그값과 비교후 계속 왼쪽인지 오른쪽인지 판단해서 붙여주면 됩니다. 또 다른 방법은 그냥 링크드리스트로 값을 입력하시고 나중에 정렬하신다음 가운데부터 위로 끌어올려주시는 방법도 있습니다. 처음 가운데 잡으면 ㅅ 이런모양이 되겠죠 그다음 현제 가운데값빼고 왼쪽에서 가운데 오른쪽에서 가운데식으로 반복해주면 그역시 훌륭한 이진트리가 됩니다.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692230 | 하노이탑 질문입니다. (1) | 미쁘다 | 2025-04-21 |
2692210 | 정보 올림피아드 문제인데.. 풀이 과정이 궁금합니다.(재귀함수) (5) | 물티슈 | 2025-04-20 |
2692144 | C언어와 리눅스에 대한 질문입니다. | 싴흐한세여니 | 2025-04-20 |
2692114 | 컨텍스트 스위칭하는데 걸리는 시간 측정.. | YourWay | 2025-04-19 |
2692086 | 간접참조 연산자, 증감연산자 질문이용! (2) | 블랙캣 | 2025-04-19 |
2692056 | 주석좀 달아주세요. 몇개적엇는데 몇개만달아주세요. (2) | DevilsTears | 2025-04-19 |
2691978 | 진수 쉽게 이해하는법... (3) | 지지않는 | 2025-04-18 |
2691949 | getchar() 한 문자를 입력받는 함수 질문 | 채꽃 | 2025-04-18 |
2691919 | 배열 정렬 및 합치기 질문입니다. | 사과 | 2025-04-18 |
2691845 | c언어왕초보 질문이 있습니다........ | 루나 | 2025-04-17 |
2691815 | void add(int num); 함수... (4) | 살랑살랑 | 2025-04-17 |
2691756 | 명령 프롬프트 스크롤바가 없어요 | 두메꽃 | 2025-04-16 |
2691725 | 자료구조에 관련해서 질문이 있어 글을 올립니다. | 누리알찬 | 2025-04-16 |
2691697 | if 문에서 구조체 배열에 저장되있던 문자열 검사하는 법 ? (2) | 민트맛사탕 | 2025-04-16 |
2691678 | C언어 함수 질문이요~!!! | 연보라 | 2025-04-15 |
2691650 | 반복문 | 돋가이 | 2025-04-15 |
2691618 | 링크드리스트 개념 질문이예요 (3) | 맨마루 | 2025-04-15 |
2691592 | 동적할당 이용 배열선언 질문입니다.ㅠㅠ (3) | 허리달 | 2025-04-15 |
2691542 | /=의 용도를 알려주세요 ㅠㅠ! (2) | 아라 | 2025-04-14 |
2691510 | sizeof 연산자 질문입니다 (2) | 종달 | 2025-04-14 |