트리에서 free하는건데요 소스간단하니 좀 봐주세요
반혈
연습삼아 해봣는데요트리 만들고 큰값을 free하는건데요맨 아래쪽 함수에서 보면 주석 달앗거든요 안되는 부분free(p)해서 트리에서 날려버릴라고 했는데 에러나서일단 0으로 초기화 했는데 보시구안되는 이유좀 써주세요 모르겠네여#includestdio.h
#includestdlib.htypedef struct node *treepointer;
typedef struct node
{
int data;
treepointer left,right;
}node;treepointer insert(treepointer p, int k); //트리 삽입
void Treeprint(treepointer p); //트리 출력
void MuxDel(treepointer p, int a); //가장 큰값 삭제
void main()
{
int i,j,k=0;
int arr[]={14,5,3,4,1,11,17,8,15}; //맨 처음 배열을 초기화 했습니다.
treepointer root;
root=(treepointer)malloc(sizeof(node));
root-data=10; //루트를 10이라고 초기화 했습니다.
root-left=NULL;
root-right=NULL;
for(i=0; i9; i++)
{
insert(root,arr[i]);
}
printf(######## ascending order #########\n);
Treeprint(root);
printf(\n);
printf(\n);
for(k=0; k5; k++) //2번만제거
{
printf( Delete : );
scanf(%d,&j);
MuxDel(root,j);
Treeprint(root);
printf(\n);
}
}treepointer insert(treepointer p, int k) //위 배열을 트리로 삽입
{
treepointer temp;
if(p == NULL)
{
temp=(treepointer)malloc(sizeof(node));
temp-data=k;
temp-left=NULL;
temp-right=NULL;
return temp;
}else if( p-data k)
{
p-left=insert(p-left,k);
return p;
}
else if( p-data k)
{
p-right=insert(p-right,k);
return p;
}
return 0;
}
void Treeprint(treepointer p) //중위 순회
{ //조건이 루트보다 작은값이 왼쪽 큰값이 오른쪽이기 떄문에
if(p) //중위 순회를 하면 오름차순으로 탐색을 한다.
{
Treeprint(p-left);
printf( %d , p-data);
Treeprint(p-right);
}
}
void MuxDel(treepointer p, int a) //가장 큰값을 삭제
{ //소스는 가장큰값을 입력해야만 삭제가 이루어집니다.
while(p)
{
if(p-data == a)
{
if(p-left != NULL ) //왼쪽 자식이 NULL값이 아닐때
{
p-data=p-left-data; //왼쪽 자식의 값을 원래 자기 위치에 놓고
p-left=NULL; //왼쪽 자식의 주소를 NULL로 지정해줍니다.
break;
}
else if(p-left == NULL ) //왼쪽 자식이 NULL값 일때
{
//free(p); // 노드를 Free하여 트리에서 끊어버립니다.
//p=NULL; // 그런데 Free와 p=NULL 쓰면 에러가 나서;;;
p-data=NULL; //삭제가 안되서 0값으로 초기화를 했습니다.
}
}
p=p-right;
}
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |
2675356 | 2진수를 10진수로 바꾸려고 하는데 막히네요.. | 풀잎 | 2024-11-17 |
2675297 | Prity 비트 발생기 | 한란 | 2024-11-16 |
2675249 | C책 좀 추천해 주세요 (2) | 딸기우유 | 2024-11-16 |
2675193 | 연습문제 17-1 질문입니다. | 한별나라 | 2024-11-15 |
2675172 | 소스점 | 아이뻐 | 2024-11-15 |