栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

单向链表删除元素操作

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

单向链表删除元素操作

说起删除,说复杂吧,也不复杂,主要是理解思路,就变得非常简单
来看看如何删除的,删除的思路是如何扭曲你的大脑的?
删除的思路:
删除的权限判断:pos>=1 pos==list.size;
参数: list,pos
判断 pos> list.size;
用c++ cerr 输出错误信息 pos 过于大
返回
定义一个用来找到pos的位置的结点
取名为current; 当前结点
定义一个常量 prevPos 初始化为:pos-1;找到前驱结点的位置 位置只能是0到list.size-1
一套循环 i

 根据i来判断 prevPos
current=current->next/找到下一个结点
当i==prevPos 退出循环

判断pos 用c++ cerr 输出错误信息 pos 过于小
返回

此时找到了待删除的结点的前驱结点 它的下一个结点就是待删除的结点
定义待删除是结点取名为DeleteNode;
将当前结点和待删除的结点传入到unLink函数中
释放 DeleteNode
–list.size;
调用完毕

删除第pos个结点元素 删除前

找到待删除的前驱结点

将待删除结点缓存

调用unLink函数

释放结点

释放结点后

更新大小

删除元素完成


链表删除操作

void LinkListDelere(LinkList& list, int pos){
	
	int i = 0;
	if (pos > (int&)list.size) {
		cerr << "pos 过于大" << endl;
		return;
	}

	LinkNode* current = list.list;
	const int  Pos = pos - 1;
	while (i < Pos ) {
		current = current->next;
		++i;
	}
	
	if (pos<=0)	{
		cerr << "pos 过于小" << endl;
		return;
	}
	LinkNode*&& DeleteNode = new (current->next)LinkNode;

	unLink(current, DeleteNode);

	delete DeleteNode;
	DeleteNode = nullptr;

	--list.size;

}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/1010470.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号