C++单链表的基本实现(带头结点)

这篇博客介绍了C++中单链表的基本操作,包括初始化、判断空链表、计算链表长度、尾插法、头插法、按值查找、按序查找、前插操作、后插操作、按序插入数据、删除操作以及遍历输出链表。示例代码展示了如何实现这些功能。
摘要由CSDN通过智能技术生成
#include<iostream>
#include<stdio.h>
#include<stdlib.h>

using namespace std;

typedef struct LNode{
	int data;//数据域 
	struct LNode *next;//指针域 
}LNode, *LinkList;

//初始化一个空的单链表 
void InitList(LinkList &L){
	L = new LNode;
	L->next = NULL;
}

//判空 
bool Empty(LinkList &L){
	return(L->next==NULL);
}

//求表长
int Length(LinkList L){
	int len = 0;
	LNode *p = L;
	while(p->next!=NULL){
		p = p->next;
		len++;
	}
	return len;
} 

//尾插法
LinkList List_TailInsert(LinkList &L){
	LNode *r = L; // r为尾指针
    int e;
    cin >> e;
    while (e != 999) {
        LNode *s = new LNode;
        s->next = r->next;
        s->data = e;
        r->next = s;
        r = s; // 将r置为新的尾指针
        cin >> e;
    }
    r->next = NULL; // 尾指针的next置为NULL
    return L;
} 

//头插法
LinkList List_HeadInsert(LinkList &L){
	LNode *s;
	int x;
	cin >> x;
	L->next = NULL;
	while(x!=999){
		cin >> x;
		LNode *s;
		s->next = L->next;
		s->data = x;
		L->next = s;
	}
	
	return L;
	
} 

//按值查找数据=e的结点 
LNode *LocateElem(LinkList &L,int e){
	LNode *p = L->next;
	while(p->next!=NULL && p->data==e){
		p = p->next;
	}
	return p;
}

//按序查找
LNode *GetElem(LinkList &L,int i){
	if(i<1)
		return NULL;
	
	LNode *p = L;
	int num = 0;
	while(p->next != NULL && num < i){
		p = p->next;
		num++;
	}
	return p;
};

//前插操作
bool InsertPriorNode(LNode *p,int e){
	if(p->next==NULL)
	return false;
	
	LNode *s = new LNode;
	s->next = p->next;
	s->data = p->data;
	p->next = s;
	p->data = e;
	
	return true;
} 

//后插操作,在p节点后插入e
bool InsertNextNode(LNode *p,int e){
	if(p->next == NULL)
	return false;
		
	LNode *q =new LNode;
	q->data = e;
	q->next = p->next;
	p->next = q;
	
	return true;
} 

//按序插入数据e 
bool InsertList(LinkList &L,int i,int e){
	if(i<1)
		return false;
	//遍历找到第i-1个结点 
	LNode *p = GetElem(L,i-1);
	
	InsertNextNode(p,e);
//	InsertPriorNode(p,e);
	return true;
}
 
//删除
bool DeleteNextNode(LNode *p,int &e){
	if(p->data==NULL)
	return false;
	if(p->next==NULL)
	return false;
	
	LNode *q = p->next;
	e = q->data;
	p->next = q->next;
	delete q;
	return true;
	
} 
//按序删除
bool ListDelete(LinkList &L,int i,int &e){
	if(i<1)
	return false;
	
	LNode *p = GetElem(L,i-1);
	
	return DeleteNextNode(p,e);
}  

//输出单链表 
void TraverseList(LinkList &L) {
    if (L->next == NULL) {
        return;
    }
    LNode *p = L->next; // 指向头指针
    while (p != NULL) {
        cout << p->data << " ";
        p = p->next;
    }
    cout << endl;
}


int main(){
	LinkList L;
	InitList(L);
	
	L = List_TailInsert(L);
//	L = List_HeadInsert(L);    头插法 
	
	Empty(L); 

	cout << "当前长度为:" << Length(L) << endl;
	
	InsertList(L,3,5);   //在序列3的位置插入数据5 
	TraverseList(L);
	
	int e;
	ListDelete(L,4,e);
	cout << "被删除的是:" << e << endl;
	TraverseList(L);
	
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值