수다닷컴

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

소스분석좀....

파라나

2023.04.01

소스분석좀....질문 요약 :소스를 보고 설명하는것좀....질문 내용 :
#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);
}

신청하기





COMMENT

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

번호 제 목 글쓴이 날짜
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
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

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