이중연결리스트 만들기..
세여닝
이중연결리스트 만들기..단일연결을 이중연결리스트 만들기요,질문 내용 : #include stdio.h
#include stdlib.h
#include string.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 addlastnode(linkedlist_h*,char*);
void reverse(linkedlist_h*);
void deletelasenode(linkedlist_h*);
void printlist(linkedlist_h*);
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 addlastnode(linkedlist_h* l,char* x)
{
listnode* newnode;
listnode* p;
newnode=(listnode*)malloc(sizeof(listnode));
strcpy(newnode-data, x);
newnode-link=null;
if(l-head==null)
{
l-head=newnode;
return;
}
p=l-head;
while(p-link!=null)
{
p=p-link;
}
p-link=newnode;
}
void reverse(linkedlist_h *l)
{
listnode* p;
listnode* q;
listnode*r;
p=l-head;
q=null;
r=null;
while(p!=null)
{
r=q;
q=p;
p=p-link;
q-link=r;
}
l-head=q;
}
void deletelastnode(linkedlist_h *l)
{
listnode* previous;
listnode* current;
if(l-head==null)return;
if( l-head-link==null)
{
free(l-head);
l-head=null;
return;
}
else
{
previous=l-head;
current=l-head-link;
while(current-link!=null)
{
previous=current;
current=current-link;
}
free(current);
previous-link=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);
}
linkedlist_h*createlinkedlist_h(void)
{
linkedlist_h* l;
l=(linkedlist_h*)malloc(sizeof(linkedlist_h));
l-head=null;
return l;
}
int main()
{
linkedlist_h* l;
l=createlinkedlist_h();
printf((1) 공백리스트 생성하기!\n);
printlist(l);
getchar();
printf((2) 리스트에 3개의 노드 추가하기!\n);
addlastnode(l,월);
addlastnode(l,수);
addlastnode(l,금);
printlist(l);
getchar();
printf((3) 리스트 마지막에 노드 한개 추가하기!\n);
addlastnode(l,일);
printlist(l);
getchar();
printf((4) 마지막 노드 삭제하기!\n);
deletelastnode(l);
printlist(l);
getchar();
printf((5)리스트 원소를 역순으로 변환하기!\n);
reverse(l);
printlist(l);
getchar();
printf((6)리스트 공간을 해제하여, 공백 리스트 상태로 만들기!\n);
freelinkedlist_h(l);
printlist(l);
getchar();
return 0;
}이걸 이중연결로 만들어야 하는데
제가 기본 지식이 하나도 없어서 그러는데 힌트좀 주세요,,, 뭐 부터 시작해야하죠,??
이론은 알겠는데 손으론 안돼요~ㅠㅠㅠㅠ
-
토리
아 해도 안됨..ㅠㅠ 좀만 손만 대주심 안돼요??? 에휴 ㅠㅠㅠㅠㅠ
-
핫파랑
노드 구조체에 지금 link 라는 자기참조 포인터가 있습니다. link 포인터는 다음 노드의 주소를 가르킵니다.
이것을 단일 링크드 리스트라고 하는것이고 이중 링크드 리스트는 다음 노드 주소와 이전 노드의 주소를 저장합니다. 현재 link 포인터 대신 다음 노드와 이전 노드를 저장 할수있는 포인터를 구현하시면됩니다.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692401 | 유닉스안에서 C언어를 이용한 명함 만들기 입니다; 이해안가는 부분이있네요 | 2gether | 2025-04-22 |
2692374 | 고수님들 댓글 마니부탁해요!!! (2) | 엄지 | 2025-04-22 |
2692343 | scnaf에 자꾸 선언을 참조하라는데;; (8) | 도래 | 2025-04-22 |
2692282 | 도스상에서 생성된 exe파일에 press~ 뜨게 하기 (4) | 회사원 | 2025-04-21 |
2692256 | scanf("%*c"); ㅠㅠ 고수님들 | 거북이 | 2025-04-21 |
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 |