算法4(力扣206)-反转链表

1、问题

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

2、采用例子

输入:head = [1,2]

输出:[2,1]

3、实现思路

改变链表箭头的指向

4、具体步骤

(1)定义链表类

(2)定义头结点

(3)实现函数

1)空链表直接返回

2)非空链表

(这里用123为例)

①创建一个临时变量,用于反转时的最终指向

​​​​​​​

②创建当前节点指向头结点

​​​​​​​

③进入循环(当前节点非空时,进入循环)

​​​​​​​

④存储当前节点的下一节点(否则反转箭头时会丢失)

⑤让当前节点指向临时变量(反转箭头)

​​​​​​​

⑥反转一个箭头后,当前节点后移(将当前节点的值赋给临时变量,类似于之前常用的cur=cur.next)

​​​​​​​

⑦临时变量的指针也后移,方便非空时进行下一次反转箭头

⑧循环外,打印并返回新链表

5、完整代码

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>反转链表</title>
</head>
<body>
    <p>
        给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。
    </p>
    <p>
        输入:head = [1,2]
        输出:[2,1]
    </p>
    <script>
        class ListNode{
            constructor(val,next){
                this.val = val
                this.next = next
            }
        }
        let head = new ListNode(1)
        head.next = new ListNode(2)
        // console.log(head);
        reverseList(head)
        function reverseList(head){
            if(!head) return head;
            //新链表的最后一位(临时变量)
            let pre = null
            let cur = head
            while (cur) {
                // nxt用于存储下一个元素
                nxt = cur.next
                // 反转链表箭头
                cur.next = pre
                // 新链表后移一位(让新链表的最后一位指针指向当前节点的前一位)
                pre = cur
                // 当前节点后移
                cur = nxt
            }  
            console.log(pre);
              
            return pre
        }
    </script>
</body>
</html>

6、力扣通过代码

javascript 复制代码
var reverseList = function(head) {
    if(!head) return head;
            //新链表的最后一位(临时变量)
            let pre = null
            let cur = head
            while (cur) {
                // nxt用于存储下一个元素
                nxt = cur.next
                // 反转链表箭头
                cur.next = pre
                // 新链表后移一位(让新链表的最后一位指针指向当前节点的前一位)
                pre = cur
                // 当前节点后移
                cur = nxt
            }  
            console.log(pre);
              
            return pre
};
相关推荐
Miraitowa_cheems24 分钟前
LeetCode算法日记 - Day 11: 寻找峰值、山脉数组的峰顶索引
java·算法·leetcode
CoovallyAIHub1 小时前
方案 | 动车底部零部件检测实时流水线检测算法改进
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
方案 | 光伏清洁机器人系统详细技术实施方案
深度学习·算法·计算机视觉
lxmyzzs1 小时前
【图像算法 - 14】精准识别路面墙体裂缝:基于YOLO12与OpenCV的实例分割智能检测实战(附完整代码)
人工智能·opencv·算法·计算机视觉·裂缝检测·yolo12
洋曼巴-young1 小时前
240. 搜索二维矩阵 II
数据结构·算法·矩阵
楼田莉子2 小时前
C++算法题目分享:二叉搜索树相关的习题
数据结构·c++·学习·算法·leetcode·面试
pusue_the_sun3 小时前
数据结构——栈和队列oj练习
c语言·数据结构·算法··队列
大锦终3 小时前
【算法】模拟专题
c++·算法
Xの哲學4 小时前
Perf使用详解
linux·网络·网络协议·算法·架构
想不明白的过度思考者4 小时前
数据结构(排序篇)——七大排序算法奇幻之旅:从扑克牌到百亿数据的魔法整理术
数据结构·算法·排序算法