이진 탐색 트리 질문
사랑해
질문 제목 : 이진 탐색 트리에서의 문제.
#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개가 뜨네요.. -_ㅠ흐흐흙......
답보다는 간단한 힌트좀 주실수 있을까요 -_ㅠ
-
가자
휴 지난주에 끝냈지만 댓글이 늦었네요 힌트 감사합니다. 아직도 갈길이 너무 많군요..
뭔가 좀더 세부적으로 배우고 기초적인것도 부족한 부분이 있다면 바로 바로 초심으로 돌아가서 배워야 할게 많다는걸 세삼스레 느꼈습니다. 좋은말씀 다시한번 감사드립니다. -
콩알녀
일단 트리로 짜신다면 생각하기 가장 편한 방법이 재귀함수입니다. 미들값을 하나 정하신다음에 그값과 비교후 계속 왼쪽인지 오른쪽인지 판단해서 붙여주면 됩니다. 또 다른 방법은 그냥 링크드리스트로 값을 입력하시고 나중에 정렬하신다음 가운데부터 위로 끌어올려주시는 방법도 있습니다. 처음 가운데 잡으면 ㅅ 이런모양이 되겠죠 그다음 현제 가운데값빼고 왼쪽에서 가운데 오른쪽에서 가운데식으로 반복해주면 그역시 훌륭한 이진트리가 됩니다.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2699024 | C언어 공부하려는데 도와주세요!!! (2) | 달님 | 2025-06-22 |
2698994 | 날짜 계산하는 C 코드 짜고 있는데 꽉 막혀서 질문드립니다.. (6) | 별 | 2025-06-22 |
2698967 | 파일삭제 윈도우 폴더까지 접근하게하는 함수가 뭔가요 (2) | 샤인 | 2025-06-21 |
2698938 | c언어 메모리질문 (3) | 나래 | 2025-06-21 |
2698909 | 서비스 요청 고객 관리 프로그램 짜는것좀 도와주세요ㅜㅜ (4) | 궁수자리 | 2025-06-21 |
2698882 | 프로그래밍좀 짜주세요 (3) | 황예 | 2025-06-21 |
2698855 | 카프-라빈 알고리즘 코딩 분석좀 도와주세요.. | 꽃봄 | 2025-06-20 |
2698829 | 학점계산기 (7) | MyWay | 2025-06-20 |
2698782 | 기초적인 함수 질문이요ㅠㅠㅠㅠ | 내담 | 2025-06-20 |
2698749 | 프로그램 짜던 도중 패닉입니다...ㅜ | 파랑 | 2025-06-19 |
2698719 | 조건부컴파일 질문입니다.~ (2) | 큐트 | 2025-06-19 |
2698693 | 재귀 함수 에러 | 바닐라 | 2025-06-19 |
2698673 | 고민이있는데 들어좀주세요!! (1) | 초코맛캔디 | 2025-06-19 |
2698644 | 1부터 n까지의 합을 구하는데 엄청긴숫자의 합을 구할때는 어떻게 해야하나요? (4) | 슬우 | 2025-06-18 |
2698616 | 다른 함수로 안넘어갑니다..;;; | 도1도캣 | 2025-06-18 |
2698587 | 배열하다 막혀서... (3) | WhiteCat | 2025-06-18 |
2698559 | 문자열을 비우는방법 (2) | 하늘 | 2025-06-18 |
2698528 | 착하고 친절한 선생씌구해염~ㅋㅋ (4) | 옆집언니야 | 2025-06-17 |
2698502 | 자료구조 큐 | 캔서 | 2025-06-17 |
2698477 | 실행화면 배경문의요 | 선아 | 2025-06-17 |