소스분석좀....
파라나
소스분석좀....질문 요약 :소스를 보고 설명하는것좀....질문 내용 :
#include stdio.h
#include stdlib.h
typedef int element;
typedef struct ListNode {
element data;
struct ListNode *link;
} ListNode;
//phead: 리스트의 헤드 포인터의 포인터
//p : 선행 노드
//new_node : 삽입될 노드
void insert_node(ListNode **phead, ListNode *p,
ListNode *new_node)
{
if(*phead == NULL){//공백리스트인 경우
new_node-link = NULL;
*phead = new_node;
}
else if( p == NULL){//p가NULL이면 첫번째 노드로 삽입
new_node-link = *phead;
*phead = new_node;
}
else{//p 다음에 삽입
new_node-link = p-link;
p-link = new_node;
}
}
//phead : 헤드 포인터에 대한 포인터
//p: 삭제될 노드의 선행 노드
//removed: 삭제될 노드
void remove_node(ListNode **phead, ListNode *p, ListNode *removed)
{
if(p==NULL)
*phead = (*phead)-link;
else
p-link = removed-link;
free(removed);
}
void display(ListNode *head)
{
ListNode *p=head;
while(p!=NULL){
printf(%d-, p-data);
p = p-link;
}
printf(\n);
}
void display_recur(ListNode *head)
{
ListNode *p=head;
if(p!=NULL){
printf(%d-, p-data);
display_recur(p-link);
}
}
ListNode *search(ListNode *head, int x)
{
ListNode *p;
p = head;
while(p!=NULL){
if(p-data == x) return p; //탐색 성공
p = p-link;
}
return p;
}
//으로 변경
ListNode *concat(ListNode *head1, ListNode *head2)
{
ListNode *p;
if(head1 == NULL)return head2;
else if(head2 == NULL)return head1;
else {
p = head1;
while(p-link!=NULL)
p = p-link;
p-link = head2;
return head1;
}
}
//로 변환
ListNode *reverse(ListNode *head)
{
//순회 포인터로 p, q, r을 사용
ListNode *p, *q, *r;
p = head;//p는 역순으로 만들 리스트
q = NULL;//q는 역순으로 만들 노드
while (p!=NULL){
r=q;//r은 역순으로 된 리스트.r은 q, q는 p를 차례로 따라간다.
q=p;
p=p-link;
q-link = r;//q의 링크 방향을 바꾼다.
}
return q;//q는 역순으로 된 리스트의 헤드 포인터
}
//노드를 동적으로 생성하는 프로그램
ListNode *create_node(element data, ListNode *link)
{
ListNode *new_node;
new_node = (ListNode *)malloc(sizeof(ListNode));
if(new_node == NULL){
fprintf(stderr, 메로리 항당 에러\n);
exit(1);
}
new_node-data = data;
new_node-link = link;
return(new_node);
}
//테스트 프로그램
void main()
{
ListNode *list1=NULL, *list2=NULL;
ListNode *p;
//list1 = 30-20-12
insert_node(&list1, NULL, create_node(10, NULL));
insert_node(&list1, NULL, create_node(20, NULL));
insert_node(&list1, NULL, create_node(30, NULL));
display_recur(list1);
//list1 = 20-10
remove_node(&list1, NULL, list1);
display(list1);
// list2 = 80-7060
insert_node(&list2, NULL, create_node(60, NULL));
insert_node(&list2, NULL, create_node(70, NULL));
insert_node(&list2, NULL, create_node(80, NULL));
display(list2);
//list1 = list1 + list2
list1 = concat(list1, list2);
display(list1);
//list1을 역순으로
list1 = reverse(list1);
display(list1);
//list1에서 20탐색
p = search(list1, 20);
printf(탐색성공: %d\n, p-data);
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2695766 | 달팽이 배열 어디서 틀렸는지 모르겠습니다ㅠㅠ | 연분홍 | 2025-05-23 |
2695738 | fopen과fclose질문~~ (5) | 희선 | 2025-05-23 |
2695707 | 3의 배수 나타내기. (2) | 수리 | 2025-05-23 |
2695626 | 피보나치수열 과제 때문에 질문 드립니다. (6) | 옆집언니 | 2025-05-22 |
2695595 | 포인트공부중입니다 int형에서 4=1 인가요? (3) | 족장 | 2025-05-22 |
2695567 | 드라이브 고유번호를 가져오는 함수 (2) | 초코맛사탕 | 2025-05-21 |
2695533 | 음수의 산술변환! 질문이요 ㅠㅠ... (4) | 꽃여름 | 2025-05-21 |
2695506 | 구조체 배열 이용 도서목록 출력 프로그램 (1) | 가을귀 | 2025-05-21 |
2695450 | c언어 함수 질문이요.... | 이슬비 | 2025-05-20 |
2695403 | VirtualAlloc함수 및 메모리 질문 | 크리에이터 | 2025-05-20 |
2695355 | c언어 for함수 | 미쿡 | 2025-05-19 |
2695327 | 안녕하세요 제가 이번에 좀 큰 프로그램을.. | 악당 | 2025-05-19 |
2695295 | mutex동기화의 thread기반 채팅 서버소스 질문입니다 | 그루터기 | 2025-05-19 |
2695270 | 질문이요..swap 관한겁니다..ㅠㅠ (3) | 콩알녀 | 2025-05-19 |
2695244 | 노땅초보궁금한게 하나 있는데요..반복문(while문)초보자질문 (6) | 큰꽃늘 | 2025-05-18 |
2695166 | do while 문 어떤것이잘못된건지 모르겠어요 (2) | 아이폰 | 2025-05-18 |
2695122 | 구조체에 대해 물어보고 싶은게 있습니다 ^^^.. (7) | 수련 | 2025-05-17 |
2695091 | txt 파일 입출력 후 2차 배열에 저장하기입니다. (3) | 헛장사 | 2025-05-17 |
2695063 | 수도요금 프로그램좀 짜주세요. | 시내 | 2025-05-17 |
2695033 | 답변좀요ㅠㅠ (1) | 비사벌 | 2025-05-16 |