数据结构 每日一练:将带头结点的单链表就地逆置(视频讲解两种方法)

目录

方法一

算法视频分析

方法二

算法视频分析


Q:什么是"就地"捏?

A:就是指辅助空间复杂度为O(1),通俗一点来说就是不需要再开辟一块空间来实现算法。

特别说明:

笔者第一次录制视频,言语有些不顺,还望大家见谅!如有错误,请大家指出。

方法一

头插法,将头结点摘下来,然后从第一结点开始,一次插入到头结点后面(头插法建立单链表),直到最后一个结点为止。

复制代码
LinkList Reverse_1(LinkList L)
{
	LNode* p, * r;         //p为工作指针,r为p的后继,以防止出现断链
	p = L->next;           //从第一个元素结点开始
	L->next = NULL;        //先将头结点L的next域置为NULL
	while (p != NULL)      //依次将元素结点断开
	{
		r = p->next;       //存放p的后继
		p->next = L->next; //将p结点插入到头结点之后
		L->next = p;
		p = r;
	}
	return L;
}

算法视频分析

方法二

假设pre,p和r指向3个结点。经过若干操作之后,*pre之前的结点的指针都已经调整完毕,它们的next都指向其原前驱节点。现在令*p结点的next域指向*pre结点,注意到一旦调整指针的指向,*p的后继结点就会断开,因此需要用r来指向原*p的后继结点。注意两点:一是再处理第一个结点时,应将其next域置为NULL ,而不是指向头结点(因为它将作为新表的尾结点);二是处理完最后一个结点后,需要将头结点的指针指向它。

复制代码
LinkList Reverse_2(LinkList L)
{
	LNode* pre, * p = L->next, * r = p->next;
	p->next = NULL;         //处理第一个结点
	while (r != NULL)       //r为空的时候说明是最后一个结点
	{
		pre = p;            //依次遍历
		p = r;
		r = r->next;
		p->next = pre;      //指针反转
	}
	L->next = p;            //处理最后一个结点
	return L;
}

算法视频分析

相关推荐
董建光d1 分钟前
【深度学习】目标检测全解析:定义、数据集、评估指标与主流算法
深度学习·算法·目标检测
赵杰伦cpp15 分钟前
list的迭代器
开发语言·数据结构·c++·算法·链表·list
~~李木子~~24 分钟前
机器学习集成算法实践:装袋法与提升法对比分析
人工智能·算法·机器学习
微笑尅乐1 小时前
三种思路彻底掌握 BST 判断(递归与迭代全解析)——力扣98.验证二叉搜索树
算法·leetcode·职场和发展
闻缺陷则喜何志丹1 小时前
【动态规划】数位DP的原理、模板(封装类)
c++·算法·动态规划·原理·模板·数位dp
豆沙沙包?1 小时前
2025年--Lc194-516. 最长回文子序列(动态规划在字符串的应用,需要二刷)--Java版
java·算法·动态规划
胖咕噜的稞达鸭1 小时前
二叉树搜索树插入,查找,删除,Key/Value二叉搜索树场景应用+源码实现
c语言·数据结构·c++·算法·gitee
showmethetime1 小时前
基于相空间重构的混沌时间序列预测MATLAB实现
算法
地平线开发者2 小时前
大模型 | VLM 初识及在自动驾驶场景中的应用
算法·自动驾驶
lingran__2 小时前
算法沉淀第四天(Winner)
c++·算法