링크드리스트 질문..
에드가
질문 제목 : 링크드리스트 코드질문좀할게요첫번째 노드로 삽입하는함수
중간노드로 삽입하는 함수
리스트 노드 삭제 함수
리스트 l에서 x노드탐색함수
이 4개 함수를 제가 만들었는데 컴파일은 되는데 실행하다가
변수 pre가 초기화 되지않고 사용되었다고오류가뜹니다 ㅠㅠ 해결좀부탁드려요
질문 내용 :
#includestdio.h
#includestdlib.h
#includestring.h
typedef struct listnode{
char data[10];
struct listnode* link; //링크필드
}listnode;
typedef struct{
listnode* head;
}linkedlist_h;
linkedlist_h* createlinkedlist_h(void); //초기화하는 함수
void freelinkedlist_h(linkedlist_h*); //메모리해제 함수
void addfirstnode(linkedlist_h*, char*); //첫번째노드에삽입하는 함수
void addmiddlenode(linkedlist_h*,listnode*, char*); //중간노드에 삽입하는 함수
listnode* searchnode(linkedlist_h* l, char* x); //노드탐색 함수
void deletenode(linkedlist_h*); //노드삭제 함수
void printlist(linkedlist_h*); //화면출력 함수
linkedlist_h* createlinkedlist_h(void){
linkedlist_h* l;
l = (linkedlist_h*)malloc(sizeof(linkedlist_h));
l - head = null;
return l;
}
void addfirstnode(linkedlist_h* l, char* x){
listnode* newnode;
newnode = (listnode*)malloc( sizeof(listnode) );
strcpy(newnode-data,x);
newnode-link = l-head;
l-head = newnode;
}
void addmiddlenode(linkedlist_h* l, listnode* pre, char* x){
listnode* newnode;
newnode = (listnode*)malloc( sizeof(listnode) );
strcpy(newnode-data,x);
pre = searchnode(l,월);
if(l-head == null){
l-head = newnode;
newnode-link = null;}
else{
newnode-link = pre-link;
pre-link = newnode;}
}
void deletenode(linkedlist_h* l){
listnode* old, * pre;
pre = searchnode(l,월);
if(l-head == null){
printf(삭제 할 노드가 없습니다.\n);}
else{
old = pre-link;
if(old == null) return;
pre-link = old-link;
}
free(old);
}
listnode* searchnode(linkedlist_h* l, char* x){
listnode* p;
p = l-head;
while(p != null) {
if(p-data == x) return p;
p = p-link;
}
return p;
}
void freelinkedlist_h(linkedlist_h* l){
listnode* p;
while(l-head != null){
p = l-head;
l-head = l-head-link;
free(p);
p=null;
}
}
void printlist(linkedlist_h* l){
listnode* p;
printf(l=();
p = l-head;
while(p != null){
printf(%s,p-data);
p = p-link;
if(p != null){
printf(,);
}
}
printf()\n);
}
int main(){
listnode* pre;
linkedlist_h* l;
l = createlinkedlist_h();
printf(공백리스트 생성하기!\n);
printf(첫번째 노드로 2개의 노드 추가하기!\n);
addfirstnode(l,수);
addfirstnode(l,월);
printlist(l);
printf(중간 노드로 1개의 노드 추가하기!\n);
addmiddlenode(l,pre,화);
printlist(l);
printf(두번째 리스트 노드 삭제하기!\n);
deletenode(l);
printlist(l);
printf(리스트 공간을 해제하여, 공백리스트 상태로 만들기!\n);
freelinkedlist_h(l);
printlist(l);
return 0;
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |
2690314 | 암호문 만들기 -비제네르- | 이퓨리한나 | 2025-04-03 |
2690292 | 왕초보자의 질문!!!!!! 도와주세요 (1) | 하랑 | 2025-04-03 |
2690269 | 정올 문제 인데.. 흠 | 반월 | 2025-04-03 |
2690237 | sizeof에서 short형을 썻는데 왜 4byte가 나올까요? (1) | 바나나 | 2025-04-03 |
2690183 | 문자열과 포인트 비교 (2) | 미즈 | 2025-04-02 |
2690154 | a -48 ? | 희미한눈물 | 2025-04-02 |
2690094 | 테트리스 질문요. | 지후 | 2025-04-01 |
2690066 | 문자열비교!! (1) | 매디 | 2025-04-01 |