연결리스트 질문입니다...
가을
질문 제목 : 연결리스트로 스택을 구현했는데, 오류가 계속 납니다...질문 요약 :제가 보기엔 계속 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와 같이 해봐도 똑같이 아예 오류가나버리고 꺼져버리네요.
컴파일러가 이상한건가ㅜㅜ 도와주세요ㅜㅜ
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692230 | 하노이탑 질문입니다. (1) | 미쁘다 | 2025-04-21 |
2692210 | 정보 올림피아드 문제인데.. 풀이 과정이 궁금합니다.(재귀함수) (5) | 물티슈 | 2025-04-20 |
2692144 | C언어와 리눅스에 대한 질문입니다. | 싴흐한세여니 | 2025-04-20 |
2692114 | 컨텍스트 스위칭하는데 걸리는 시간 측정.. | YourWay | 2025-04-19 |
2692086 | 간접참조 연산자, 증감연산자 질문이용! (2) | 블랙캣 | 2025-04-19 |
2692056 | 주석좀 달아주세요. 몇개적엇는데 몇개만달아주세요. (2) | DevilsTears | 2025-04-19 |
2691978 | 진수 쉽게 이해하는법... (3) | 지지않는 | 2025-04-18 |
2691949 | getchar() 한 문자를 입력받는 함수 질문 | 채꽃 | 2025-04-18 |
2691919 | 배열 정렬 및 합치기 질문입니다. | 사과 | 2025-04-18 |
2691845 | c언어왕초보 질문이 있습니다........ | 루나 | 2025-04-17 |
2691815 | void add(int num); 함수... (4) | 살랑살랑 | 2025-04-17 |
2691756 | 명령 프롬프트 스크롤바가 없어요 | 두메꽃 | 2025-04-16 |
2691725 | 자료구조에 관련해서 질문이 있어 글을 올립니다. | 누리알찬 | 2025-04-16 |
2691697 | if 문에서 구조체 배열에 저장되있던 문자열 검사하는 법 ? (2) | 민트맛사탕 | 2025-04-16 |
2691678 | C언어 함수 질문이요~!!! | 연보라 | 2025-04-15 |
2691650 | 반복문 | 돋가이 | 2025-04-15 |
2691618 | 링크드리스트 개념 질문이예요 (3) | 맨마루 | 2025-04-15 |
2691592 | 동적할당 이용 배열선언 질문입니다.ㅠㅠ (3) | 허리달 | 2025-04-15 |
2691542 | /=의 용도를 알려주세요 ㅠㅠ! (2) | 아라 | 2025-04-14 |
2691510 | sizeof 연산자 질문입니다 (2) | 종달 | 2025-04-14 |