트리에서 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;
}
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2691169 | 동적할당 어디가 잘못된걸까요. | 츠키 | 2025-04-11 |
2691082 | puts vs printf | 리네 | 2025-04-10 |
2691058 | (C언어) 구구단을 작성해 봤는데 문제가 발생했습니다. (6) | 제나 | 2025-04-10 |
2690947 | 윈도우 메모장에서 버츄얼박스 우분투 붙여넣기 질문 (1) | 유우 | 2025-04-09 |
2690920 | 무슨 의미 인가요? | 딸기맛캔디 | 2025-04-09 |
2690891 | c++ 은행계좌 프로그램 | 알찬마루 | 2025-04-08 |
2690834 | c언어 if문에서 출력 질문합니다 ㅜㅜ (2) | 파랑새 | 2025-04-08 |
2690809 | c언어 질문좀 부탁드리겠습니다 | 개구리 | 2025-04-08 |
2690777 | 말 표현에서 궁금한점이 있습니다. 배열을 통째로 넘겨받으려면 매개변수로 배열을 선언할 수 있어야한다? (8) | 별햇님 | 2025-04-07 |
2690749 | 피라미드 질문드립니다 (for문 한개) | 도래솔 | 2025-04-07 |
2690718 | 함수 포인터반환 함수 질문 | 에드워드 | 2025-04-07 |
2690685 | 2중for문 도와주세여..;; | 흰추위 | 2025-04-07 |
2690655 | 팩토리얼 계산문제..질문~ (9) | 옆집꼬마야 | 2025-04-06 |
2690627 | c 변수 선언후 변수값 저장안하고 출력 | 방방 | 2025-04-06 |
2690600 | 릴리즈 모드로 컴파일해서 다른 컴퓨터에서도 실행파일을 실행할수 있는 방법 알려주세요 (5) | 제나 | 2025-04-06 |
2690576 | bin파일 저장 | 다올 | 2025-04-06 |
2690547 | C언어 뒷부분이라 너무 어려워서요;; 프로그래밍 하나만 부탁드립니다 (4) | 그루터기 | 2025-04-05 |
2690517 | cygwin에서요.. (1) | 엘보어 | 2025-04-05 |
2690486 | 문자열과 문자형이요 ~ | 다스리 | 2025-04-05 |
2690344 | 일본어 주석 깨짐 문제 (3) | 연하얀 | 2025-04-04 |