当前位置: 首页 > article >正文

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

1、问题

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

2、采用例子

        输入:head = [1,2]

        输出:[2,1]

3、实现思路

        改变链表箭头的指向

4、具体步骤

(1)定义链表类

        

(2)定义头结点

        

(3)实现函数

        1)空链表直接返回

                

        2)非空链表

               

                        (这里用123为例)

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

        ​​​​​​​        

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

        ​​​​​​​        

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

        ​​​​​​​            

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

                

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

        ​​​​​​​        

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

        ​​​​​​​        

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

                       

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

                

5、完整代码

<!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、力扣通过代码


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
};


http://www.kler.cn/a/509930.html

相关文章:

  • LabVIEW 蔬菜精密播种监测系统
  • Python爬取豆瓣图书网Top250 实战
  • docker 基础语法学习,K8s基础语法学习,零基础学习
  • Excel 技巧10 - 如何检查输入重复数据(★★)
  • 计算机网络-数据链路层
  • 学习记录1
  • Hack The Box-Starting Point系列Oopsie
  • TCP Window Full是怎么来的
  • 游戏画质升级史的思考
  • DEBERTA:具有解耦注意力机制的解码增强型BERT
  • 豆包MarsCode:构造特定数组的逆序拼接
  • 通信协议之多摩川编码器协议
  • LabVIEW 实现线路板 PCB 可靠性测试
  • 网络安全 | 域名和DNS详解
  • vim使用指南
  • Armv8/Armv9架构从入门到精通-介绍
  • nss刷题3
  • .Net Core微服务入门系列(一)——项目搭建
  • Conda 常用操作命令与使用示例
  • CC工具箱使用指南:【Excel点集转面要素(批量)】
  • 请简述公司的系统服务架构类型(单体架构、分布式架构、微服务架构、分层架构、集群架构、SOA 架构、中台架构)
  • Reactor 模式在 Edis、Nginx 和 Netty 中的应用与高性能网络模式解析
  • 青少年编程与数学 02-007 PostgreSQL数据库应用 01课题、PostgreSQL数据库
  • Day30下 - RAG系统
  • 实现星海波动粒子特效:基于 Canvas 和 JavaScript 的 3D 波动效果
  • P7865 「EVOI-RD1」无人机航拍( ( [主题训练B1]线段树 ) 第四题)[ 采用高级二维差分数组 ]