链表转置算法

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就是转置后的链表了

相关推荐
奶茶树17 分钟前
【数据结构】二叉搜索树
数据结构·算法
晨曦(zxr_0102)36 分钟前
CSP-X 2024 复赛编程题全解(B4104+B4105+B4106+B4107)
数据结构·c++·算法
ai安歌36 分钟前
【Rust编程:从新手到大师】 Rust 控制流深度详解
开发语言·算法·rust
Shinom1ya_38 分钟前
算法 day 36
算法
·白小白40 分钟前
力扣(LeetCode) ——15.三数之和(C++)
c++·算法·leetcode
海琴烟Sunshine41 分钟前
leetcode 268. 丢失的数字 python
python·算法·leetcode
CL.LIANG1 小时前
视觉SLAM前置知识:相机模型
数码相机·算法
无限进步_1 小时前
深入理解C语言scanf函数:从基础到高级用法完全指南
c语言·开发语言·c++·后端·算法·visual studio
Lei_3359671 小时前
[算法]十大排序
数据结构·算法·排序算法
大数据张老师2 小时前
数据结构——堆排序
数据结构·算法·排序算法