算法题解-回文链表

简介: 算法题解-回文链表

题目


给你一个单链表的头节点 head ,请你判断该链表是否为回文链表。如果是,返回 true ;否则,返回 false

输入: head = [1,2,2,1]
输出: true


题解


第一种


我们在函数中先判断头节点是否为空,如果为空,则直接返回true,因为空链表也可以认为是回文链表,接下来我们使用双指针的方式来找到链表的中间节点,即慢指针slow变量和快指针fast变量,其中慢指针每次移动一步,快指针每次移动两步,当快指针到达链表尾部时,慢指针指向的节点就是链表的中间节点,如果链表长度为奇数,慢指针正好指向中间节点,如果链表长度为偶数,慢指针指向的是中间两个节点的前一个节点,接下来声明一个名为reverseList的函数,该函数的作用是将一个链表进行翻转,它使用递归的方式实现,首先递归到链表最后一个节点,然后将最后一个节点作为新的头节点返回,并把前面的节点依次指向它,将链表中间节点后面的部分进行翻转,返回翻转后的链表头节点,我们这里进行调用,在函数中我们使用两个指针分别指向链表前半部分和反转后的后半部分,依次比较两个节点的值是否相等,如果不相等则返回false,这也说明了链表不是回文链表,否则继续往后比较,如果整个链表都比较完毕后,没有返回false,则说明链表是回文链表,我们返回true即可

var isPalindrome = function(head) {
    if(!head) return true;
    let slow = head, fast = head.next;
    while(fast && fast.next) {
        slow = slow.next;
        fast = fast.next.next;
    }
    let back = reverseList(slow.next);
    while(back) {
        if(head.val !== back.val) {
            return false;
        }
        head = head.next;
        back = back.next;
    }
    return true;
};
function reverseList(head){
    if(!head || !head.next) return head;
    const r = reverseList(head.next);
    head.next.next = head;
    head.next = null;
    return r;
}


第二种


我们在函数中先定义两个指针slow和fast,初始值都指向链表的头部,然后我们使用循环,每次slow指针向后移动一位,fast指针向后移动两位,直到fast指针指向链表尾部或者倒数第二个节点,在循环中我们将slow指针经过的节点的值存入ary数组中,如果fast指针指向链表尾部,说明链表长度为奇数,此时slow指针指向的是中间节点,需要将其向后移动一位,跳过中间节点,如果fast指针指向倒数第二个节点,说明链表长度为偶数,此时slow指针指向的是前半部分的最后一个节点,我们不需要进行额外的移动,接下来我们使用循环进行遍历后半部分的节点,同时从数组ary中取出对应的值进行比较,如果有不相同的值,则说明不是回文链表,返回false反之则返回true即可

function isPalindrome(head){
    let slow = head, fast = head
    let ary = []
    while(fast && fast.next){
        ary.unshift(slow.val)
        slow = slow.next
        fast = fast.next.next
    if(fast){
        slow = slow.next
    }
    let i = 0
    while(slow){
        if(slow.val !== ary[i]){
            return false
        }
        i++
        slow = slow.next
    }
    return true
};
相关文章
|
5月前
|
存储 算法 物联网
解析局域网内控制电脑机制:基于 Go 语言链表算法的隐秘通信技术探究
数字化办公与物联网蓬勃发展的时代背景下,局域网内计算机控制已成为提升工作效率、达成设备协同管理的重要途径。无论是企业远程办公时的设备统一调度,还是智能家居系统中多设备间的联动控制,高效的数据传输与管理机制均构成实现局域网内计算机控制功能的核心要素。本文将深入探究 Go 语言中的链表数据结构,剖析其在局域网内计算机控制过程中,如何达成数据的有序存储与高效传输,并通过完整的 Go 语言代码示例展示其应用流程。
101 0
|
6月前
|
存储 监控 算法
员工电脑监控系统中的 C# 链表算法剖析-如何监控员工的电脑
当代企业管理体系中,员工电脑监控已成为一个具有重要研究价值与实践意义的关键议题。随着数字化办公模式的广泛普及,企业亟需确保员工对公司资源的合理利用,维护网络安全环境,并提升整体工作效率。有效的电脑监控手段对于企业实现这些目标具有不可忽视的作用,而这一过程离不开精妙的数据结构与算法作为技术支撑。本文旨在深入探究链表(Linked List)这一经典数据结构在员工电脑监控场景中的具体应用,并通过 C# 编程语言给出详尽的代码实现与解析。
104 5
|
7月前
|
存储 机器学习/深度学习 算法
C 408—《数据结构》算法题基础篇—链表(下)
408考研——《数据结构》算法题基础篇之链表(下)。
197 30
|
7月前
|
存储 算法 C语言
C 408—《数据结构》算法题基础篇—链表(上)
408考研——《数据结构》算法题基础篇之链表(上)。
303 25
|
7月前
|
存储 监控 算法
公司监控上网软件架构:基于 C++ 链表算法的数据关联机制探讨
在数字化办公时代,公司监控上网软件成为企业管理网络资源和保障信息安全的关键工具。本文深入剖析C++中的链表数据结构及其在该软件中的应用。链表通过节点存储网络访问记录,具备高效插入、删除操作及节省内存的优势,助力企业实时追踪员工上网行为,提升运营效率并降低安全风险。示例代码展示了如何用C++实现链表记录上网行为,并模拟发送至服务器。链表为公司监控上网软件提供了灵活高效的数据管理方式,但实际开发还需考虑安全性、隐私保护等多方面因素。
112 0
公司监控上网软件架构:基于 C++ 链表算法的数据关联机制探讨
|
10月前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习之单双链表精题详解(9)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
10月前
|
存储 Web App开发 算法
2024重生之回溯数据结构与算法系列学习之单双链表【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构之单双链表按位、值查找;[前后]插入;删除指定节点;求表长、静态链表等代码及具体思路详解步骤;举例说明、注意点及常见报错问题所对应的解决方法
|
11月前
|
存储 缓存 算法
经典算法之链表篇(三)
经典算法之链表篇(三)
163 4
|
11月前
|
算法
经典算法之链表篇(二)
经典算法之链表篇(二)
154 4
|
11月前
|
算法 索引
经典算法之链表篇
经典算法之链表篇
106 4

热门文章

最新文章