头插法和尾插法建立单链表

/*头插法和尾插法建立单链表*/ 
#include <iostream>
using namespace std;
typedef int ElemType;
typedef struct LNode {
	ElemType data;//定义数据域,存放元素值 
	struct LNode *next; 
}LinkList;
 
 
//头插法建表(从尾部一个一个往前插入)
void CreateListHead(LinkList *&L, ElemType a[], int n){ //用来暂时存放数据 
	LinkList *s;
	L = (LinkList *)malloc(sizeof(LinkList));//创建头节点
	L->next = NULL; //将头结点next域置空
	for(int i = 0; i < n; i++) {	//循环建立数据结点
		s = (LinkList *)malloc(sizeof(LinkList));
		//将结点s插在原开始节点之前,头结点之后
		s->data = a[i];//数据放到数据域 
		s->next = L->next;//此时将s的next区域置为空
		L->next = s;//指向数据域 
		
	} 
}


//尾插法建表(一个接一个从头插入) 
void CreateListTail(LinkList *&L, ElemType a[], int n) {
	LinkList *s, *r;
	L = (LinkList *)malloc(sizeof(LinkList));//创建头节点
	r=L;//r始终指向尾结点,开始时头结点和尾结点是同一个
	for(int i = 0; i < n; i++) {
		s = (LinkList *)malloc(sizeof(LinkList));//创建数据结点
		s->data = a[i];//数据域 
		r->next = s;//将s插入到r后 
		r = s;//r每次指向最后一个节点 
	} 
	r->next = NULL; 
}

void DispList(LinkList *L) {
	LinkList *p = L->next;//p指向开始节点 
	while(p != NULL) {
		cout << p->data << " ";//数据数据域 
		p = p->next;
	}
}

int main(){    
	LinkList *L;	
	int n;	
	cout << "请输入链表元素的个数n:";	
	cin >> n;
	int a[10000];	
	for(int i = 0;i < n; i++){	  
		cin >> a[i];	
	}	
//头插法建表	
	CreateListHead(L, a, n);		
	cout << "头插法建表:";	
	DispList(L);//输出 
	cout << endl;	
//尾插法建表	
	CreateListTail(L, a, n);		
	cout << "尾插法建表:";	
	DispList(L);//输出
	cout << endl;
	return 0;
} 

头插法和尾插法建立单链表