연결리스트 질문입니다...
가을
질문 제목 : 연결리스트로 스택을 구현했는데, 오류가 계속 납니다...질문 요약 :제가 보기엔 계속 free함수 쓰는데서 오류가 나는거같은데, 무슨이윤지 모르겠습니다ㅜㅜ질문 내용 :
이 경우도 마찬가지로 컴파일링은 잘 되는데 실행하면 오류가 발생합니다.typedef struct STACK{
int data;
struct STACK *next;
} STACK;
int pop(STACK *s)
{
int result=0;
STACK *p, *prev;
if(top(s)1){
printf(\n Stack Underflow!\n);
return FALSE;
}
p=s;
while(p){
prev=p;
p=p-next;
}
result=prev-data;
prev-next=NULL;
return result;
}
void print_stack(STACK *s)
{
int i;
STACK *p, *prev, copy;
p=s;
copy=*p;
i=top(©);
for(i;i1;i--){
p=©
while(p){
prev=p;
p=p-next;
}
printf(stack[%d]|%5d|\n,i-1,prev-data);
free(prev);
}
}int main()
{
STACK *s;
int k=0;
int *q;
s=init_stack();
while(1){
printf(Insert data for stack(exit for 9999) :);
scanf(%d, &k);
if(k==9999) break;
push(k,s);
}
k=top(s);
for(k;k1;k--){
printf(%d,k);
printf(\npopping data : %d\n\n,pop(s));
}
pop(s);
return 0;
}여기서 top 함수는 리스트 크기를 구하는 함수로 제대로 작동하는걸 확인했습니다..
붉은색으로 굵게 표시한 부분이 문제가 되는것 같은데요,
원래는 모두 free(prev)로 마무리될 부분인데
실행을 시키면 pop을 하는 과정에서 계속 똑같은 값이 반환됩니다(마지막에 넣은 값)
그래서 free가 안되나? 싶어서 저렇게도 해보고 prev-next=prev-next-next와 같이 해봐도 똑같이 아예 오류가나버리고 꺼져버리네요.
컴파일러가 이상한건가ㅜㅜ 도와주세요ㅜㅜ
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676182 | 숫자 순서대로 배열하는법 | 권뉴 | 2024-11-24 |
2676152 | 기본적인거 하나 질문드립니다. | 개미 | 2024-11-24 |
2676124 | 함수선언관련 질문이에요~...털썩..수정완료 (2) | 가지 | 2024-11-24 |
2676092 | C언어 책 (2) | 아서 | 2024-11-24 |
2676065 | 웹사이트 또는 메신저 등에서 원하는 텍스트를 검사하는방법?? (1) | 모든 | 2024-11-23 |
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 |