当前位置: 首页 > news >正文

阜南县建设局网站织梦网站模板如何安装教程视频

阜南县建设局网站,织梦网站模板如何安装教程视频,房地产销售新手入门知识,怎么添加网站背景音乐💬 欢迎讨论:在阅读过程中有任何疑问,欢迎在评论区留言,我们一起交流学习! 👍 点赞、收藏与分享:如果你觉得这篇文章对你有帮助,记得点赞、收藏,并分享给更多对数据结构感…

💬 欢迎讨论:在阅读过程中有任何疑问,欢迎在评论区留言,我们一起交流学习!
👍 点赞、收藏与分享:如果你觉得这篇文章对你有帮助,记得点赞、收藏,并分享给更多对数据结构感兴趣的朋友

文章目录

    • 快慢指针
      • 核心思想
    • 找中点问题:
      • 思路讲解
      • 核心代码
      • 完整代码
    • 寻找倒数第 k 个节点:
      • 思路讲解
      • 代码解析
    • 结语

快慢指针

快慢指针(Fast and Slow Pointers)是一种常用于解决链表、数组等数据结构问题的算法技巧,通过两个指针以不同速度遍历数据来高效解决问题

核心思想

  • 快指针:每次移动 两步(或自定义步长)。
  • 慢指针:每次移动 一步
  • 目的:利用速度差,在单次遍历中解决特定问题(如检测循环、找中点等)。

找中点问题:

链表的中间结点 - 力扣(LeetCode)

给你单链表的头结点 head ,请你找出并返回链表的中间结点。

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

示例 1:

**输入:**head = [1,2,3,4,5]
输出:[3,4,5]
**解释:**链表只有一个中间结点,值为 3 。

示例 2:

**输入:**head = [1,2,3,4,5,6]
输出:[4,5,6]
**解释:**该链表有两个中间结点,值分别为 3 和 4 ,返回第二个结点。

思路讲解

定义一个步长为2的快指针fast,一个步长为1的慢指针slow,从头开始同时遍历该链表,当fast指向尾节点或为空时,slow恰好指向中间节点。

核心代码

while(fast && fast->next){slow = slow->next;//slow每次走一步fast = fast->next->next;//fast每次走两步}
  • 链表只有一个中间结点,fast->next为空停止,slow为这个中间节点
  • 如果有两个中间结点,fast为空停止,slow为第二个中间节点。

完整代码

struct ListNode* middleNode(struct ListNode* head) {struct ListNode* slow = head;struct ListNode* fast = head;while(fast && fast->next){slow = slow->next;fast = fast->next->next;}return slow;
}

寻找倒数第 k 个节点:

返回倒数第 k 个节点 - 力扣(LeetCode)
实现一种算法,找出单向链表中倒数第 k 个节点。返回该节点的值。

示例:

输入: 1->2->3->4->5 和 k = 2
输出: 4

说明:

给定的 k 保证是有效的。

思路讲解

定义一对快慢指针指向链表头部,先让快指针走k步,使得快指针与慢指针相距k,然后再让两个指针以相同的速度同时走,当快指针走到空时,慢指针指向的位置就是倒数第k个节点

在这里插入图片描述

代码解析

int kthToLast(struct ListNode* head, int k) {
//定义一对快慢指针指向链表头部struct ListNode* fast = head;struct ListNode* slow = head;//先让快指针走k步,使得快指针与慢指针相距kwhile(k--){fast = fast->next;}//让两个指针以相同的速度同时走,当快指针走到空时,慢指针指向的位置就是倒数第k个节点while(fast){fast = fast->next;slow = slow->next;}return slow->val;
}

结语

如果读者觉得不过瘾,那就再来两题吧~
141. 环形链表 - 力扣(LeetCode)
19. 删除链表的倒数第 N 个结点 - 力扣(LeetCode)

本文只讲解了两个简单的题目,目的在于帮助读者打好基础,下一篇文章将要讲解的带环链表也会用到快慢指针,届时读者可以对其有更深层次的认知。

http://www.dtcms.com/a/436546.html

相关文章:

  • 网站ico设计大连网站排名推广
  • 如何让你的Stata接入大模型Agent?Stata MCP+ IDE配置教程
  • 做外贸网站哪家的好开发公司对联
  • 腾讯云手动搭建wordpress个人站点百度广告联盟一个月能赚多少
  • 做家乡网站的素材内蒙古建设厅设计处网站
  • 网站建设公司益阳建设局网站
  • 网站建设基本流程教学视频iis6.0建立网站
  • 可以用什么网站做mc官方画册设计网站欣赏
  • dw可以做视频网站么上海将打造五大未来产业集群
  • 网站做tipswordpress数据文件
  • 深圳网站制作必选祥奔科技免费发布网站
  • 做图素材的网站有哪些wordpress摄影模板
  • 查询建设资质的网站开发一个app有哪些好处
  • 商丘做网站公司新站seo快速收录网站内容页的方法润州网站建设
  • 厦门建设银行网站怎么进入网站开发模式
  • 网站建设与规划的书做pc端网站价位
  • 网站底部悬浮代码dedecms制作的网站
  • 怎么做网站的seo排名知乎android官网
  • 做查询网站费用石家庄邮电职业技术学院
  • 专门做机器人的网站建设英文网站赚钱的36个方法
  • 怎么推广自己的网站贵州百度推广优化报告
  • 左、右伪逆
  • 东莞网站建设哪里好高端品牌护肤品有哪些
  • 衡水网站建设选哪家流量对于网站盈利
  • 深圳网博网站建设制作网页填数据
  • 后台管理系统网站模板凡科网站怎么做外链
  • 用c语言做网站网站的模块
  • 济宁北湖建设局网站域名购买查询
  • 做网站的基本流程wordpress怎样加入代码
  • 阿里域名价格wordpress和seo权重