js算法——实现反转链表

简介: js算法——实现反转链表


题目来自leetcode

定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。

输入: 1->2->3->4->5->NULL

输出: 5->4->3->2->1->NULL

/**
 * Definition for singly-linked list.
 * function ListNode(val) {
 *     this.val = val;
 *     this.next = null;
 * }
 */
/**
 * @param {ListNode} head
 * @return {ListNode}
 */
var reverseList = function(head) {
};


首先考链表,我们要对链表解构以及栈堆内存十分清晰。

我们要知道我们对链表进行遍历是必然的,所以可以写出

var reverseList = function(head) {
    let curr = head;
    while (curr) {
       //进入下一个循环
       curr=curr.next
    }
};

当我们当头部开始时,头部成了尾部,应该指向null,所以我们应该创建一个null节点,所以第一次遍历时,是头部指向一个null。

但是当我们修改了当前节点的next之后,链表被切断,我们就不能用它进行遍历了,所以我们得要保存被切断之后的链表,声明一个next指针保存

var reverseList = function(head) {
    let res = null
    let curr = head;
    while (curr) {
       const next=curr.next
       curr.next=res
       //进入下一个循环我们要思考一个问题...
       curr=curr.next
    }
};

image.png

上述代码说了进入下一个循环前我们要思考一个问题。

当我们遍历到第二步时,我们希望的是curr能够指向1那个节点,可是没有栈内存也就是没有指针指向它,因此我们要在遍历到下一步时,可以用res指向它。

var reverseList = function(head) {
    let res = null
    let curr = head
    while (curr) {
       const next=curr.next 
       curr.next=res
       //进入下一个循环前该做的事,对应图中步骤1,然后开始循环
       res=curr
       curr=next
    }
};

image.png

res就会指向反转链表的头部,返回即可

var reverseList = function(head) {
    let res = null
    let curr = head
    while (curr) {
       const next=curr.next 
       curr.next=res
       res=curr
       curr=next
    }
    return res
};

提升


k个一组反转?


将反转定义一个方法。

在头部声明一个dummy指向head,作为第一组需要反转的链表的头部,并额外声明两个指针pre和end。

用end.next作为循环结束的条件。

将end移动k个链,若在移动中变为空说明已经没有可以旋转的k个链了,跳出循环。

将end.next置为空,意思就是让原链表从end处截断,但是在反转链表中我们已经学过了,我们应该声明一个next把end后面的链表保存,不然后面内容就丢失了。

用start指向pre.next,用于反转,因为end在k个链处被截断了,所以刚好反转k个。然后用pre接收,也就是把反转的内容连在dummy后面,反转完,start指向的位置是dummy链的尾部,我们只需要让start.next指向原来保存的next,也就是start作为新一组要反转的链表的头部,将pre和end指向它进入循环。

var reverseKGroup = function(head, k) {
   //解释1
   const rev=(start)=>{
     let res=null
     while(start!==null){
         const next=start.next
         start.next=res
         res=start
         start=next
     }
     return res
   }
   //解释2
   const dummy=new ListNode(0,head)
   let pre=dummy,end=dummy
   //解释3
   while(end.next!==null){
      //解释4
      for(let i=0;i<k&&end!==null;i++) end=end.next
      if(end===null) break
      //解释5
      const next=end.next
      end.next=null
      //解释6
      let start=pre.next
      pre.next=rev(start)
      start.next=next
      pre=start
      end=start
   }
   return dummy.next
};


相关文章
|
1月前
|
算法
【❤️算法笔记❤️】-每日一刷-19、删除链表的倒数第 N个结点
【❤️算法笔记❤️】-每日一刷-19、删除链表的倒数第 N个结点
65 1
|
1月前
|
算法 索引
❤️算法笔记❤️-(每日一刷-141、环形链表)
❤️算法笔记❤️-(每日一刷-141、环形链表)
46 0
|
1月前
|
算法
【❤️算法笔记❤️】-(每日一刷-876、单链表的中点)
【❤️算法笔记❤️】-(每日一刷-876、单链表的中点)
43 0
|
1月前
|
算法
【❤️算法笔记❤️】-每日一刷-23、合并 K 个升序链表
【❤️算法笔记❤️】-每日一刷-23、合并 K 个升序链表
32 0
|
1月前
|
存储 算法
【❤️算法笔记❤️】-每日一刷-21、合并两个有序链表
【❤️算法笔记❤️】-每日一刷-21、合并两个有序链表
90 0
|
20天前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习之单双链表精题详解(9)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
20天前
|
存储 Web App开发 算法
2024重生之回溯数据结构与算法系列学习之单双链表【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构之单双链表按位、值查找;[前后]插入;删除指定节点;求表长、静态链表等代码及具体思路详解步骤;举例说明、注意点及常见报错问题所对应的解决方法
|
2月前
|
算法 JavaScript 前端开发
第一个算法项目 | JS实现并查集迷宫算法Demo学习
本文是关于使用JavaScript实现并查集迷宫算法的中国象棋demo的学习记录,包括项目运行方法、知识点梳理、代码赏析以及相关CSS样式表文件的介绍。
第一个算法项目 | JS实现并查集迷宫算法Demo学习
|
1月前
|
存储 缓存 算法
经典算法之链表篇(三)
经典算法之链表篇(三)
|
1月前
|
算法
经典算法之链表篇(二)
经典算法之链表篇(二)