链表转置算法

Question

给出链表node,如何转置并输出

例如链表node:

node(0)->node(1)->node(2)->node(3)->node(4)

输出结果:

node(4)->node(3)->node(2)->node(1)->node(0)

Answer

**思考步骤:**遍历一次就要形成一个新的转置链表,首先想到的就是链表头插法,头插法逻辑:

java 复制代码
public void addFirst(ListNode newNode,ListNode head) {
    //链表头插法
    newNode.next = head;
    head = newNode;
}

那么梳理一下------

遍历第一次:

java 复制代码
node(0).next = head
head = node(0);

遍历第二次:

java 复制代码
node(1).next = head
head = node(1);

......

遍历最后一次:

java 复制代码
node(4).next = head
head = node(4);

看上去很简单,整个遍历完毕后,就是

node(4)->node(3)->node(2)->node(1)->node(0)结果,但是运行的时候发现不正确,原因很简单

我们在遍历链表的时候肯定是这么来的

java 复制代码
while(n != null) {
	//...
	n = n.next
}

但是我们在上文遍历的情况下,设置了node(x).next = head,这个会导致链表的next指针被修改了,那么n.next肯定指向不了真正的下一个对象

java 复制代码
//有问题的代码
ListNode pre = null;
while (n != null) {
    //头插法
    n.next = pre;
    pre = n;
    n = n.next;   //这里实际上被上文的n.next = pre;覆盖了,导致循环不了!!!
}

所以我们需要定义一个临时变量,保存链表的next内容

java 复制代码
//正确代码
ListNode pre = null;
while (n != null) {
    ListNode t = n.next;   //临时保存next对象

    //头插法
    n.next = pre;
    pre = n;

    n = t;   //使用上文临时保存的next对象,保证能够正常迭代
}

最后输出的pre就是转置后的链表了

相关推荐
_日拱一卒3 分钟前
LeetCode:矩阵置零
java·数据结构·线性代数·算法·leetcode·职场和发展·矩阵
穿条秋裤到处跑5 分钟前
每日一道leetcode(2026.04.10):三个相等元素之间的最小距离 I
算法·leetcode
nlpming15 分钟前
OpenClaw 代码解析
算法
学习永无止境@18 分钟前
MATLAB中矩阵转置
算法·matlab·fpga开发·矩阵
七颗糖很甜19 分钟前
雨滴谱数据深度解析——从原始变量到科学产品的Python实现【下篇】
python·算法·pandas
nlpming19 分钟前
OpenClaw system prompt定义
算法
nlpming19 分钟前
OpenClaw安装配置及简介
算法
爱码小白20 分钟前
MySQL 常用数据类型的系统总结
数据库·python·算法
玛丽莲茼蒿27 分钟前
Leetcode hot100 【中等】括号生成
算法·leetcode·职场和发展
小欣加油29 分钟前
leetcode 128 最长连续序列
c++·算法·leetcode·职场和发展