单链表的实现

单链表

cpp 复制代码
#include<stdio.h>
#include<string.h>
#include<stdlib.h>

typedef struct lianbiao
{
	int num;
	struct lianbiao* next;
}LB;
//头插 
void toucha(LB** pc, int x)
{
	LB* newnode = (LB*)malloc(sizeof(LB));
	newnode->num = x;
	newnode->next = NULL;
	if (*pc == NULL)
	{
		*pc = newnode;
	}
	else
	{
		newnode->next = *pc;
		*pc = newnode;
	}
}

//打印 
void Print(LB* pc)
{
	LB* cur = pc;
	while (cur)
	{
		printf("%d ", cur->num);
		cur = cur->next;
	}
	printf("null\n");
}

//尾插 
void weicha(LB** pc, int x)//尾插
{
	LB* newnode = (LB*)malloc(sizeof(LB));
	newnode->num = x;
	newnode->next = NULL;
	if (*pc == NULL)
	{
		*pc = newnode;
	}
	else
	{
		//法1 
//		//找尾	
//		LB*cur=*pc;
//		while(cur->next!=NULL)
//		{
//			cur=cur->next;			
//		}
//		cur->next=newnode;	

		//法二 
		LB* cur = *pc;//因为改变的是地址,所以打印时首元素地址也变了,
		//所以要存一下,开头地址 
		while ((*pc)->next != NULL)
		{
			(*pc) = (*pc)->next;
		}

		(*pc)->next = newnode;
		*pc = cur;
	}
}
//头删
void toushan(LB** pc)
{
	if (*pc == NULL)
	{
		return;
	}
	else
	{
		LB* cur = *pc;
		*pc = cur->next;
		free(cur);
		cur = NULL;
	}

}
//尾 删 ,3种情况 
void weishan(LB** pc)
{
	if (*pc == NULL)//为空 
	{
		return;
	}


	if ((*pc)->next == NULL)//只有一个节点 
	{
		free(*pc);
		*pc = NULL;
	}

	else//多个节点 
	{
		LB* cur = *pc;

		LB* tail = NULL;
		while (cur->next != NULL)
		{
			tail = cur;
			cur = cur->next;
		}

		free(cur);
		cur = NULL;

		tail->next = NULL;//最重要一步,尾删后,要把删的前一个赋成NULL 
	}

}

//查找和修改 
LB* chazhao(LB* pc, int x)
{
	LB* cur = pc;
	while (cur)
	{
		if (cur->num == x)
		{
			return cur;
		}
		cur = cur->next;
	}
	return NULL;
}

//在pos之前插入
void posqiancha(LB**pc,LB*pos,int x)
{
	if (pos==*pc)//当需要插入的位置在开头,直接头插
	{
		toucha(pc, x);//pc本来传过来的时候就是&tou,所以直接传pc
	}
	else
	{
		LB* newnode = (LB*)malloc(sizeof(LB));
		newnode->num = x;
		newnode->next = NULL;

		LB* cur = *pc;
		while (cur->next != pos)
		{
			cur = cur->next;
		}
		cur->next = newnode;
		newnode->next = pos;
	}
}
//pos位置删除
void posshan(LB** pc, LB* pos)
{
	if (*pc == pos)
	{
		LB* cur = *pc;
		*pc = cur->next;
		free(cur);
		cur = NULL;

		//头删toushan(pc,pos);
	}

	else
	{
		LB* cur = *pc;
		while (cur->next != pos)
		{
			cur = cur->next;
		}
		cur->next = pos->next;
		free(pos);
		cur = cur->next;
	}
	
}

//pos后面插入
void poshoucha(LB**pc,LB*pos,int x)
{
	LB* newnode = (LB*)malloc(sizeof(LB));
	newnode->num = x;
	newnode->next;

	if (*pc == NULL)
	{
		toucha(pc, x);
	}

	else 
	{
		LB* cur = *pc;
		while (cur != pos)
		{
			cur = cur->next;
		}
		newnode->next = pos->next;
		pos->next = newnode;
	}
}

//pos位置后面删除
void poshoushan(LB**pc,LB*pos )
{
	//cur->next = pos->next->next;直接这样写,中间节点会消失
	//存一下要删除的节点
	LB* del = pos->next;
	pos->next = del->next;
	free(del);
	del = NULL;
}

	int main()
	{
		LB* tou = NULL;
	 //   toucha(&tou,1);//头插 
	//	Print(tou);//打印 

	//weicha(&tou, 2);//尾插 
	//weicha(&tou, 2);
	//weicha(&tou, 2);
	weicha(&tou, 2);
	weicha(&tou, 7);
	weicha(&tou, 9);
	weicha(&tou, 9);
	weicha(&tou, 9);

	/*Print(tou);*/

	//头删
	//toushan(&tou);
	//toushan(&tou);
	//	Print(tou);	

		//尾删 
	/*weishan(&tou);
	weishan(&tou);*/
	//	Print(tou);

		//查找和修改 
	LB* ret = chazhao(tou, 2);
	//ret->num *= 2;
	//Print(tou);

	//在pos之前插入
	//posqiancha(&tou,ret,3);
	//Print(tou);


	//pos位置删除
	//posshan(&tou,ret);
	//Print(tou);

	//pos后面插入
	/*poshoucha(&tou,ret,9);
	Print(tou);*/

	//pos位置后面删除
	poshoushan(&tou,ret);
	Print(tou);
	return 0;
}
相关推荐
CSharp精选营4 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
刘马想放假8 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠8 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦15 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠16 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾16 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres82116 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q16 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒17 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记17 天前
单项不带头不循环链表
数据结构·链表