수다닷컴

  • 해외여행
    • 괌
    • 태국
    • 유럽
    • 일본
    • 필리핀
    • 미국
    • 중국
    • 기타여행
    • 싱가폴
  • 건강
    • 다이어트
    • 당뇨
    • 헬스
    • 건강음식
    • 건강기타
  • 컴퓨터
    • 프로그램 개발일반
    • C언어
    • 비주얼베이직
  • 결혼생활
    • 출산/육아
    • 결혼준비
    • 엄마이야기방
  • 일상생활
    • 면접
    • 취업
    • 진로선택
  • 교육
    • 교육일반
    • 아이교육
    • 토익
    • 해외연수
    • 영어
  • 취미생활
    • 음악
    • 자전거
    • 수영
    • 바이크
    • 축구
  • 기타
    • 강아지
    • 제주도여행
    • 국내여행
    • 기타일상
    • 애플
    • 휴대폰관련
  • 프로그램 개발일반
  • C언어
  • 비주얼베이직

단순연결리스트에서 소스해석이~

인1형녀

2023.04.01

#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 addLastNode(linkedList_h*, char*);
void reverse(linkedList_h*);
void deleteLastNode(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 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){
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 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()
{
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();
getchar();
return 0;
}

L-head 이것이 가리키는것이 노드 부분의 제일 처음인가요?? 아니면 제일 끝부분인가요???
addLastNode 함수에서 p=L-head ;부분이 있는데제가분석할때는 제일 처음으로 가리킨다고 해석해서는
수요일 노드가 추가되지 않더라구요... 끝부분을 나타내는거면 분석이 되던데... 제가잘 모르고 있는건지.. 아니면 head가 제일 끝부분을 가리키는건지 잘 모르겟네요.

그리고 만약에 끝부분을 가리킨다고 했을시에는 printList 부분에서 p=L-head 부분이 있는데 끝부분을 가리키면
역순으로 출력이 되더라구요...

그래서 질문을 정리하면

p=L-head 가 무엇을 뜻하는거죠?
그리고 L-head이 가장 앞 노드를 가리키는것인가요?
아니면 제일 끝부분을 가리키는것인가요?

addLastNode 부분에서 p=L-head 가 좀 헷갈리더라구요....ㅜㅜ
질문이 두서없었는데 너무 답답해서 질문을 올립니다.

신청하기





COMMENT

댓글을 입력해주세요. 비속어와 욕설은 삼가해주세요.

  • 레이

    추가적으로 p=L-head; 이 부분이 필요한 것은
    p = p-link; 이 부분을 이용하기 위해서 head를 이용하는것입니다.
    head 다음의 주소를 가져와서 NULL인지 체크하여 NULL일 때까지 반복하게 되는거죠

    이 부분을 계속 반복해주기 때문에 NULL이 되는 순간 그 곳이 마지막 부분이므로
    NULL대신에 malloc을 통해 할당받은 newnode의 주소를 집어넣는 거에요.

  • 낶아

    L-head 는 제일 처음을 가리키는게 맞습니다
    하지만 그 바로 밑에 while문이 보이시나요?

    그 부분에서 head부분을 이용하여 제일 끝 부분.
    즉, NULL이 나올 때까지 계속 돕니다.

    그러니 제일 마지막 부분에 추가가 되는것이죠 ㅎㅎ

번호 제 목 글쓴이 날짜
2700095 연산문제...질문... 오빤테앵겨 2025-07-01
2700070 while문 , 3의배수 출력하는 프로그램좀 짜주세욤. 횃불 2025-07-01
2700041 초보인데요 ㅎ 배열안에 배열을 집어넣을수 있나요?? 헛장사 2025-07-01
2700012 배열// (1) 전갈자리 2025-07-01
2699895 무한루프에 빠집니다.!! 해결좀부탁드려요 (10) 선아 2025-06-30
2699842 질문을 너무 많이 하네여.....죄송.... (2) 해님꽃 2025-06-29
2699816 오류 질문입니다.. (1) 해비치 2025-06-29
2699763 질문입니다 ! 꼭 좀 도와주세요ㅠㅠ (2) 미라 2025-06-28
2699555 c언어 다항식을 입력을 했는데 왜 출력이 안될까요? 피스케스 2025-06-27
2699528 C언어 포인터연산 질문입니다. (3) 안녕나야 2025-06-26
2699476 끌어올림;;달력 짜봤는데요 이 소스 줄일 수 있나요? - 스샷첨부 (2) 클라우드 2025-06-26
2699444 [좀 급함] system("explorer [주소] ") 문에 변수를 사용할 수 있나요? 알 2025-06-26
2699415 파일//read//와 배열 아란 2025-06-25
2699386 구조체 안에 일부분만 char 배열에 복사하려면 어떻게 해야하나요? (1) 미즈 2025-06-25
2699361 연결리스트 정렬하는 부분에 대해서 질문 드립니다 아이처럼 2025-06-25
2699304 [기초]아직 안주무시는분 계신가요..?포인터배열? 좀 도와주세요. 놀리기 2025-06-24
2699272 printf() 함수이용해서 프로그램 만들기 질문요! (5) 다가 2025-06-24
2699221 PUSH와 POP코드를 더 간단하게 어떻게 해야할까요? 파라미 2025-06-24
2699192 설치오류가 자꾸 나요 한번봐주세여~ (1) 소녀틳향기 2025-06-23
2699161 for loop안에 있는 if문 (9) Orange 2025-06-23
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

수다닷컴 | 여러분과 함께하는 수다토크 커뮤니티 수다닷컴에 오신것을 환영합니다.
사업자등록번호 : 117-07-92748 상호 : 진달래여행사 대표자 : 명현재 서울시 강서구 방화동 890번지 푸르지오 107동 306호
copyright 2011 게시글 삭제 및 기타 문의 : clairacademy@naver.com