15天算法入门(五)

简介: 今天考察的是双指针加链表的操作。必须要回顾一下链表的反转、删除、增加等基础操作,最为经典的还是取中间数的几种情况。

网络异常,图片无法展示
|


网络异常,图片无法展示
|
今天考察的是双指针加链表的操作。必须要回顾一下链表的反转、删除、增加等基础操作,最为经典的还是取中间数的几种情况。


链表的中间节点


题目


给定一个头结点为 head 的非空单链表,返回链表的中间结点。

如果有两个中间结点,则返回第二个中间结点。

示例 1:
输入:[1,2,3,4,5]
输出:此列表中的结点 3 (序列化形式:[3,4,5])
返回的结点值为 3 。 (测评系统对该结点序列化表述是 [3,4,5])。
注意,我们返回了一个 ListNode 类型的对象 ans,这样:
ans.val = 3, ans.next.val = 4, ans.next.next.val = 5, 以及 ans.next.next.next = NULL.


题解


使用快慢指针,快指针一次走两格,慢指针一次一格。这样返回的慢指针正好指向中间节点。


只是需要考虑的是:节点是欧偶数个的时候,中间节点返回的是第二个节点。节点上取整还是下取整是根据快慢指针的起始位置决定的。

  • 如果偶数个上取整的话,直接从头节点开始:快指针两格,慢指针一格。
  • 如果偶数个下取整的话,就要从头节点的下一个节点开始,这样才能确保快指针走完后,慢指针指向的是中间节点的第二个节点。

网络异常,图片无法展示
|

网络异常,图片无法展示
|

代码

var middleNode = function (head) {
    if (head == null || head.next == null) return head
    let f = head.next, s = head.next
    while (f.next != null && f.next.next != null) {
        s = s.next
        f = f.next.next
    }
    return s
};


删除链表的倒数第 N 个结点


题目


给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。

进阶:你能尝试使用一趟扫描实现吗?

示例 1:
输入:head = [1,2,3,4,5], n = 2
输出:[1,2,3,5]


题解


这题依旧使用快慢指针来解决。不过题目求的是到第N个,我们可以将快指针先走N步,然后让快慢指针同时同向而行,直到快指针遍历完成。


此时,慢指针正好指在到数第N+1的位置,然后使用链表的删除操作将N位置的节点删除。


最后直接返回原链表即可。

网络异常,图片无法展示
|

代码


var removeNthFromEnd = function (head, n) {
    if (head == null) return head
    let f = head, s = head
    while (n) {
        f = f.next
        n--
    }
    if (f == null) return head.next
    while (f.next != null) {
        f = f.next
        s = s.next
    }
    s.next = s.next.next
    return head
};


题目来源:leetcode

目录
相关文章
|
1月前
|
机器学习/深度学习 人工智能 算法
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
本文全面介绍了人工智能(AI)的基础知识、操作教程、算法实现及其在实际项目中的应用。首先,从AI的概念出发,解释了AI如何使机器具备学习、思考、决策和交流的能力,并列举了日常生活中的常见应用场景,如手机助手、推荐系统、自动驾驶等。接着,详细介绍了AI在提高效率、增强用户体验、促进技术创新和解决复杂问题等方面的显著作用,同时展望了AI的未来发展趋势,包括自我学习能力的提升、人机协作的增强、伦理法规的完善以及行业垂直化应用的拓展等...
148 3
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
|
2月前
|
机器学习/深度学习 数据采集 人工智能
机器学习算法入门与实践
【7月更文挑战第22天】机器学习算法入门与实践是一个既充满挑战又极具吸引力的过程。通过掌握基础知识、理解常见算法、注重数据预处理和模型选择、持续学习新技术和参与实践项目,你可以逐步提高自己的机器学习技能,并在实际应用中取得优异的成绩。记住,机器学习是一个不断迭代和改进的过程,保持好奇心和耐心,你将在这个领域走得更远。
|
2月前
|
消息中间件 存储 算法
实战算法的基础入门(2)
实战算法的基础入门
|
2月前
|
算法 大数据
实战算法的基础入门(1)
实战算法的基础入门
|
1月前
|
存储 算法
【C算法】编程初学者入门训练140道(1~20)
【C算法】编程初学者入门训练140道(1~20)
|
2月前
|
算法 Java
实战算法的基础入门(3)
实战算法的基础入门
|
3月前
|
算法 程序员
高阶算法班从入门到精通之路
高阶算法班从入门到精通之路
30 3
|
3月前
|
机器学习/深度学习 人工智能 自然语言处理
机器学习算法入门:从K-means到神经网络
【6月更文挑战第26天】机器学习入门:从K-means到神经网络。文章涵盖了K-means聚类、逻辑回归、决策树和神经网络的基础原理及应用场景。K-means用于数据分组,逻辑回归适用于二分类,决策树通过特征划分做决策,神经网络则在复杂任务如图像和语言处理中大显身手。是初学者的算法导览。
|
3月前
|
自然语言处理 算法
ransformers从入门到精通:常用的subword tokenizer算法
- WordPiece、BPE/BBPE最小字词进行合并最终字词,BPE/BBPE直接采用词频判断合并规则而WordPiece采用最大似然的方式 - unigram采用从最大的字词集合里移除那些对语料库整体概率贡献最小的子词【6月更文挑战第7天】
75 3
|
3月前
|
存储 自然语言处理 算法
位运算入门及简单算法题的应用
位运算入门及简单算法题的应用
26 1