跳至主要內容

删除链表中重复的结点

微信公众号:储凡2023/2/11小于 1 分钟

删除链表中重复的结点

题目链接

题目描述

刷题思路

代码实现

/*
 * @Description: 【较难】删除链表中重复的结点
 * @Version: Beta1.0
 * @Author: 微信公众号:储凡
 * @Date: 2021-05-02 09:02:18
 * @LastEditors: 微信公众号:储凡
 * @LastEditTime: 2021-05-02 09:15:24
 */

function ListNode(x) {
  this.val = x
  this.next = null
}

// 注意是排序的结点
// 这种先遍历,再借用临时变量 也可以考虑用递归
export function deleteDuplication(pHead) {
  // 定义map
  const map = new Map()
  while (pHead) {
    const value = map.has(pHead.val) ? map.get(pHead.val) + 1 : 1
    map.set(pHead.val, value)

    // 下一个元素
    pHead = pHead.next
  }
  // 遍历map 找出值为1的
  let result = new ListNode(-1)
  const pre = result
  for (const m of map) {
    const [key, count] = m
    // 尾插法
    if (count === 1) {
      result.next = new ListNode(key)

      // 指针后移
      result = result.next
    }
  }
  // pre为结果链表的头结点 ,去除-1;
  return pre.next
}

/**
 * 基于递归
 */
export function deleteDuplication01(head) {
  if (head === null || head.next === null) {
    return head
  }

  // 前后结点都不为空,比较val值
  let nextNode = head.next
  if (head.val === nextNode.val) {
    while (nextNode !== null && head.val === nextNode.val) {
      // 值相同的情况 移动到下一个结点
      nextNode = nextNode.next
    }
    // 过滤掉值相同的,递归
    return deleteDuplication01(nextNode)
  }
  else {
    // 值不同,将头结点的下一个位置指向
    head.next = deleteDuplication01(head.next)
    // 返回头结点
    return head
  }
}

一些建议

更新日志

2024/7/29 15:43
查看所有更新日志
  • 5a2b2-feat: 移除markdown-cli模块,采用prettier校验文档格式
  • c0f2d-refactor: 升级vuepress相关版本,优化项目结构 (#137)
  • 06596-feat: 算法相关文档新增固定链接,优化导入代码配置
  • 9b9e4-feat: 算法相关文档更新,删除讨论链接 (#88)
  • b0275-feat(markdownlint-cli): 添加markdown文档校验,支持lint脚本自动格式化文档
  • 5f1e1-feat: 导航栏、侧边栏内容修改,新增目录对应的文档
  • 02ab1-style: 文档目录调整,修改mdEnhance配置
  • 8de1a-feat: 剑指算法文档更新,修改目录结构
  • d0347-docs(algorithm): 新增模版格式
  • 74e84-docs(algorithm): 新增一些文档
  • ced18-docs: 更新一些文档,优化导航栏
  • a23ce-refactor: 新增manuscript目录,优化文稿结构
  • e34c0-style(code): 代码风格eslint格式化,新增部分文档
  • 74aa9-docs(algorithm): 新增一些文档
  • 3c22c-refactor: 新增Eslint配置,修改相关代码风格
  • 9bbe9-feat: 修改导航栏结构,添加文档
  • e4c74-feat: 新增算法源码
贡献者: chu fan,Chu Fan,chufan,142vip.cn,chufan443