头插法和尾插法图文并茂

原文链接:http://blog.csdn.net/Fire_Sky_Ho/article/details/78072052?locationNum=4&fps=1

本文更好的排版方式:头插法与尾插法

 

#include "stdio.h"
#include "stdlib.h"
typedef struct List 
{
	int data; //数据域
	struct List *next; //指针域
} List;
void TailCreatList(List *L) //尾插法建立链表
{
	List *s, *r;//s用来指向新生成的节点。r始终指向L的终端节点。
	r = L; //r指向了头节点,此时的头节点是终端节点。
	for (int i = 0; i < 10; i++) {
	s = (struct List*) malloc(sizeof(struct List));//s指向新申请的节点
	s->data = i; //用新节点的数据域来接受i
	r->next = s; //用r来接纳新节点
	r = s; //r指向终端节点
	}
	r->next = NULL; //元素已经全部装入链表L中
	//L的终端节点指针域为NULL,L建立完成
}
void HeadCreatList(List *L) //头插法建立链表
{
	List *s; //不用像尾插法一样生成一个终端节点。
	L->next = NULL;
	for (int i = 0; i < 10; i++) {
	s = (struct List*) malloc(sizeof(struct List));
	s->data = i;
	s->next = L->next; //将L指向的地址赋值给S;//头插法与尾插法的不同之处主要在此,
	//s所指的新节点的指针域next指向L中的开始节点
	L->next = s; //头指针的指针域next指向s节点,使得s成为开始节点。
	}
}
void DisPlay(List *L) 
{ 	//打印节点
	List *p = L->next;
	while (p != NULL) {
	printf("%d ", p->data);
	p = p->next;
	}
	printf("\n");
}
int main() 
{
	List *L1, *L2;
	L1 = (struct List*) malloc(sizeof(struct List));
	L2 = (struct List*) malloc(sizeof(struct List));
	HeadCreatList(L1);
	DisPlay(L1);
	TailCreatList(L2);
	DisPlay(L2);
}

程序运行结果如下:

头插法和尾插法图文并茂_第1张图片

 

你可能感兴趣的:(C/C++,数据结构和算法)