수다닷컴

  • 해외여행
    • 괌
    • 태국
    • 유럽
    • 일본
    • 필리핀
    • 미국
    • 중국
    • 기타여행
    • 싱가폴
  • 건강
    • 다이어트
    • 당뇨
    • 헬스
    • 건강음식
    • 건강기타
  • 컴퓨터
    • 프로그램 개발일반
    • C언어
    • 비주얼베이직
  • 결혼생활
    • 출산/육아
    • 결혼준비
    • 엄마이야기방
  • 일상생활
    • 면접
    • 취업
    • 진로선택
  • 교육
    • 교육일반
    • 아이교육
    • 토익
    • 해외연수
    • 영어
  • 취미생활
    • 음악
    • 자전거
    • 수영
    • 바이크
    • 축구
  • 기타
    • 강아지
    • 제주도여행
    • 국내여행
    • 기타일상
    • 애플
    • 휴대폰관련
  • 프로그램 개발일반
  • C언어
  • 비주얼베이직

이진 탐색 트리 질문

사랑해

2023.04.01

질문 제목 : 이진 탐색 트리에서의 문제.
#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개가 뜨네요.. -_ㅠ흐흐흙......
답보다는 간단한 힌트좀 주실수 있을까요 -_ㅠ

신청하기





COMMENT

댓글을 입력해주세요. 비속어와 욕설은 삼가해주세요.

  • 가자

    휴 지난주에 끝냈지만 댓글이 늦었네요 힌트 감사합니다. 아직도 갈길이 너무 많군요..
    뭔가 좀더 세부적으로 배우고 기초적인것도 부족한 부분이 있다면 바로 바로 초심으로 돌아가서 배워야 할게 많다는걸 세삼스레 느꼈습니다. 좋은말씀 다시한번 감사드립니다.

  • 콩알녀

    일단 트리로 짜신다면 생각하기 가장 편한 방법이 재귀함수입니다. 미들값을 하나 정하신다음에 그값과 비교후 계속 왼쪽인지 오른쪽인지 판단해서 붙여주면 됩니다. 또 다른 방법은 그냥 링크드리스트로 값을 입력하시고 나중에 정렬하신다음 가운데부터 위로 끌어올려주시는 방법도 있습니다. 처음 가운데 잡으면 ㅅ 이런모양이 되겠죠 그다음 현제 가운데값빼고 왼쪽에서 가운데 오른쪽에서 가운데식으로 반복해주면 그역시 훌륭한 이진트리가 됩니다.

번호 제 목 글쓴이 날짜
2694929 열혈강의 25-2 두번째 문제 질문 지우개 2025-05-15
2694900 dequeue 에서 리턴값 프린트 방법알려주세요 오늘 12시까지 대화방에 있습니다 도와주세요 미투리 2025-05-15
2694854 절대값을 구할때 (2) 그녀는귀여웠다 2025-05-15
2694827 이제 어떻게 공부해야할지 모르겠네요 새얀 2025-05-14
2694778 순열 계산요. 맛조이 2025-05-14
2694754 ShowWindow 함수를 이용하려 하는데 질문있습니다. (2) 파도 2025-05-14
2694731 리눅스 커널의 시작점 질문 미르 2025-05-13
2694702 이거 뭐가문제인가요 코드수정좀 (3) 맑은 2025-05-13
2694675 C언어 후위표기를 중위표기로 앨런 2025-05-13
2694646 안녕하세요 파일 합치기 함수! (1) 연블루 2025-05-13
2694618 잘몰라서 설명부탁드립니다. scanf 관련 (3) 파라 2025-05-12
2694590 이 코드가 뭐하는 코드일까요? #2 빵순 2025-05-12
2694559 동적할당으로 배열(2차원열)을 만드는데 있어 그걸 함수화시키는데... (1) 늘솔길 2025-05-12
2694532 네트워크에 관하여... (4) 황소자리 2025-05-12
2694503 프로그램 연산 후 바로 종료되는 현상 (6) Judicious 2025-05-11
2694450 while문질문입니다. (1) 허리품 2025-05-11
2694420 C언어 질문할게요(유니코드,자료형,버퍼,캐스트연산자) 은새 2025-05-11
2694370 내일까진데 함수호출 제발 도와주세요!!!!!!!!!11 들찬 2025-05-10
2694339 putchar()의 괄호 안에 int c=10;로 전에 선언된 c를 넣으면 안되는 이유에서 제가 생각한 것이 그 이유가 되는지 확인하고 싶습니다. (3) 미르 2025-05-10
2694316 이 코드 어디가 잘못되었는지 고수분들 ㅠㅠ (2) 나빛 2025-05-10
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

수다닷컴 | 여러분과 함께하는 수다토크 커뮤니티 수다닷컴에 오신것을 환영합니다.
사업자등록번호 : 117-07-92748 상호 : 진달래여행사 대표자 : 명현재 서울시 강서구 방화동 890번지 푸르지오 107동 306호
copyright 2011 게시글 삭제 및 기타 문의 : clairacademy@naver.com