【JavaScript版数据结构与算法面向大厂面试】第五章 数据结构之“链表”

第五章 数据结构之“链表”

5.1 链表简介

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  1. 利用abojct创建一个链表
    const a = {val: ‘a’};
    const b = {val: ‘b’};
    const c = {val: ‘c’};
    const d = {val: ‘d’};
  2. 用指针把a, b, c, d关联起来
    a.next = b;
    b.next = c;
    c.next = d;
  3. 遍历链表
    let p = a; // 声明一个指针p且指向a
    while 循环,指针存在时,打印对应的值
    while§ {//在p还有值的前提下不断地把p移动到下一个值
    console.log(p.val);//访问链表里面每个元素的值
    p = p.next; // 移动指针
    }
  4. 在链表中插入值,把e插入c和d之间
    const e = {val: ‘e’};
    c.next = e;//改变指针的指向
    e.next = d;
  5. 删除 :改变c的指针,e被删除
    c.next = d;

5.2 LeetCode:237,删除链表中的节点

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

node.val = node.next.val;//把下一个节点的值赋值给该节点
node.next = node.next.next;//该节点的指针指向下下一个节点

/**
 * Definition for singly-linked list.
 * function ListNode(val) {
 *     this.val = val;
 *     this.next = null;
 * }
 */
/**
* @param {ListNode} node
* @return {void} Do not return anything, modify node in-place instead.
*/
var deleteNode = function (node) {
   
    node.val = node.next.val;//把当前节点的值设置成下个节点的值    
    node.next = node.next.next;//删除下个节点:直接把next的指针指向下下个节点

};

5.3 LeetCode:206,反转链表

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

解题思路:

  1. 从简单开始,找到规律多次重复
  2. 翻转1个 n+1 指向n. 后边的指向前面
  3. 使用两个指针遍历,对两个指针指向进行翻转,然后两个指针都迭代到下两个,进行同样的操作

解题步骤:

  1. 声明两个指针
  2. 确定指向位置
  3. 让两个指针迭代起来,遍历整个链表
  4. 像不像排序里,交换两个变量。
/**
 * Definition for singly-linked list.
 * function ListNode(val, next) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.next = (next===undefined ? null : next)
 * }
 */
/**
* @param {ListNode} head
* @return {ListNode}
*/
var reverseList = function (head) {
   

    let p1 = head;//p1指向1
    let p2 = null;//p2指向null
    //遍历链表
    while (p1) {
   
        const tmp = p1.next;  //新建一个变量用来存储,p1.next的值
        console.log(p1.val, p2 && p2.val); //p2有可能会为空,所以要保证p2不为空的前提下取到p2.val
        p1.next =
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@ZGLi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值