알고리즘관련 메모리해제 질문..
혁민
알고리즘 질문인데 알고리즘 게시판 활성화가 잘되지 않은거 같아서 여기다가 질문글올립니다 양해부탁드려요 ㅠㅠ
질문은 메모리해제인데요 책을보니 약간 복잡한 함수로 알고리즘 메모리해제가 되있길래요
소스에서 제가 빨간색으로 노드의 헤드파일을 메모리해제시켰는데
이렇게 시켜도 동적할당된 모든 메모리가 해제되는건가요?
노드 동적할당된거야 아래 removenode함수로 다 제거해버리면되는데
link 헤드파일 제거도 이렇게 간단하게 free로만해서도 완벽히 제거했다고 볼수있는건가요?
궁금합니다 ㅠ.ㅠ
---------------------------------
헤더파일
#ifndef _LINKEDLIST_
#define _LINKEDLIST_
typedef struct listnodetype
{
int data;
struct listnodetype *nextnode;
}node;
typedef struct linkedlisttype
{
int count;
node header;
}link;
#endif
#ifndef _TF_
#define _TF_
#define TRUE 1
#define FALSE 0
#endif
------------------------------
소스파일#include stdio.h
#include stdlib.h
#include 1.h
#include string.h
link *create();
int addnode(link *plist,int data);
node *getnode(link *plist,int num);
void displaynode(link *plist);
int removenode(link *plist,int p);
int main(int argc,char *argv[])
{
int i=0;
link *plist=NULL;
plist=create();
if(plist!=NULL)
{
addnode(plist,100);
addnode(plist,200);
addnode(plist,300);
removenode(plist,1);
displaynode(plist);
free(plist);
}
return 0;
}
link *create()
{
link *plist=NULL;
plist=(link*)malloc(sizeof(link));
if(plist!=NULL)
{
memset(plist,0,sizeof(link));
}
else
{
printf(동적할당 실패!!\n);
return NULL;
}
return plist;
}
int addnode(link *plist,int data)
{
int i=0;
int ret=FALSE;
node element;
node *newnode=NULL;
node *prevnode=NULL;
element.data=data;
if(plist!=NULL)
{
newnode=(node*)malloc(sizeof(node));
if(newnode!=NULL)
{
*newnode=element;
newnode-nextnode=NULL;
prevnode=&(plist-header);
for(i=0;iplist-count;i++)
prevnode=prevnode-nextnode;
prevnode-nextnode=newnode-nextnode;
prevnode-nextnode=newnode;
plist-count++;
ret=TRUE;
}
else
{
printf(노드생성 오류입니다!!\n);
return ret;
}
}
else
printf(잘못된 헤드노드입니다!!\n);
return ret;
}
node *getnode(link *plist,int num)
{
node *dummy=NULL;
node *preturn=NULL;
int fakei=plist-count;
int i=0;
if(plist!=NULL)
{
dummy=&(plist-header);
for(i=0;i=num;i++)
dummy=dummy-nextnode;
preturn=dummy;
}
return preturn;
}
void displaynode(link *plist)
{
int i=0;
if(plist!=NULL)
{
printf(현 원소개수:%d\n,plist-count);
for(i=0;iplist-count;i++)
printf([%d],%d\n,i,getnode(plist,i)-data);
}
else
printf(원소가 없습니다\n);
}
int removenode(link *plist,int p)
{
node *removenode=NULL;
node *dummy=NULL;
int ret=FALSE;
int i=0;
if(plist!=NULL)
{
if(p=plist-count)
{
dummy=&(plist-header);
for(i=0;ip;i++)
{
dummy=dummy-nextnode;
}
removenode=dummy-nextnode;
dummy-nextnode=removenode-nextnode;
free(removenode);
plist-count--;
ret=TRUE;
}
else
printf(노드 위치오류!!---[%d]---\n,p);
}
return ret;
}
-----------------
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2700695 | 간단한 메모장 구현을 할려고 하는데요 (9) | 늘솜 | 2025-07-07 |
2700668 | c언어 질문입니다. 도와주세요~ (3) | 가자 | 2025-07-07 |
2700639 | 한글입력받아서 ㄱㄴㄷ순서대로출력하는법좀 | 두빛나래 | 2025-07-06 |
2700610 | 정말 기초적인 더하기,여백 문제 help | 무슬 | 2025-07-06 |
2700562 | 함수포인터에서요 (7) | 소심한여자 | 2025-07-06 |
2700530 | 전처리문 질문입니다. (1) | 아놀드 | 2025-07-05 |
2700510 | c언어를 어케하면 잘할수 있을까요.. | 연연두 | 2025-07-05 |
2700484 | 두 개가 차이가 뭔지 알려주세요...(소수 찾는 프로그램) (2) | 날위해 | 2025-07-05 |
2700426 | 인터넷 창 띄우는 질문이요 (1) | 정훈 | 2025-07-04 |
2700400 | 원넓이를 계산이요 ㅜㅜ | 천칭자리 | 2025-07-04 |
2700368 | if에 관해서 질문이요... | Orange | 2025-07-04 |
2700339 | 이거 결과값이 왜이런건지.. (4) | 그댸와나 | 2025-07-04 |
2700313 | 파일 읽어서 저장하는데 빈파일일 경우 문재가 발생하네요.. (2) | 크나 | 2025-07-03 |
2700287 | 구조체 동적할당 연습을 하는데 오류가 뜹니다...(해결) (3) | 아련나래 | 2025-07-03 |
2700264 | 문자와 숫자 동시에 입력??? | 글고운 | 2025-07-03 |
2700236 | txt파일로만 쓰고 읽게 하려면 어떻게 해야 하나요..?? (8) | 미국녀 | 2025-07-03 |
2700211 | 전위 연산자 (2) | 어른처럼 | 2025-07-02 |
2700183 | C에서 파일이름을 받고, 그 파일의 사이즈를 출력해줘야하는데 내용이 출력이 안되네요 ;ㅅ; | 피스케스 | 2025-07-02 |
2700150 | 꼭좀 도와주세요ㅠㅠㅠ | 호습다 | 2025-07-02 |
2700095 | 연산문제...질문... | 오빤테앵겨 | 2025-07-01 |