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

/*头插法和尾插法建立单链表*/ 
#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;
} 

  • 6
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

金州饿霸

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值