연결리스트 개선
일본어못해요
질문 요약 :연결리스트 개선할 점 요청질문 내용 : 직접 오늘 만들어본 단순 연결리스트인데 개선할 점을 노력한 분(?)께 요청해봅니다.
메모리 해제는 제외하고 부탁합니다.#include stdio.h
#include stdlib.h // malloc(), free()
#include string.h // strcpy()
#define MAX_NUM 5// 노드 생성 개수
/******************************
* 사용자 정의 자료형 *
* 구조체: Node *
* 멤 버: name - 이름*
* age - 나이*
* pNext - next 노드*
*****************************/
typedef struct Node {
char name[10];
int age;
struct List* pNext;
} Node;
/* head, tail 초기화 */
Node* head = NULL;
Node* tail = NULL;
/*********************
* 사용자 정의 함수 *
* insert: 노드 생성 *
* print : 노드 출력 *
********************/
void insert(void);
void print(void);
int main(void)
{
int i = 0;
/* 생성 */
while( i++ MAX_NUM )
insert();
/* 출력 */
print();
return 0;
}
void insert(void)
{
Node* node;
/* 데이터 초기화 */
node = (Node*)malloc(sizeof(Node));
printf(이름: );
gets(node-name);
printf(나이: );
scanf(%d, &node-age);
fflush(stdin);
/* 노드가 하나도 없을 때 */
if(head == NULL)
head = node;
/* 노드가 하나라도 있을 때 */
else
{
tail = head;
// 마지막 노드로 이동
// 노드가 2개 이상 있을 때 실행됨
while(tail-pNext != NULL)
tail = tail-pNext;
// 생성한 노드를 마지막 노드로 설정
tail-pNext = node;
}
node-pNext = NULL;
}
void print(void)
{
Node* pTmp = head;
/* 노드가 없을 때 */
if(head == NULL)
return;
/* 노드가 하나 이상 있을 때 */
while(pTmp != NULL)
{
printf(name: %s \n, pTmp-name);
printf( age: %d \n, pTmp-age);
pTmp = pTmp-pNext;
}
}