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

创业做网站 优帮云最好看的直播免费的

创业做网站 优帮云,最好看的直播免费的,网站开发的运行可行性,北京网站建设大概多少钱3道链表力扣题 一、删除链表中的节点🌏 题目链接📕 示例🍀 分析💻 代码 二、反转链表🌏 题目链接📕 示例🍀 分析① 递归② 迭代 三、判断一个链表是否有环🌏 题目链接📕 …

3道链表力扣题

  • 一、删除链表中的节点
    • 🌏 题目链接
    • 📕 示例
    • 🍀 分析
    • 💻 代码
  • 二、反转链表
    • 🌏 题目链接
    • 📕 示例
    • 🍀 分析
      • ① 递归
      • ② 迭代
  • 三、判断一个链表是否有环
    • 🌏 题目链接
    • 📕 示例
    • 🍀 分析
    • 💻 代码

一、删除链表中的节点

🌏 题目链接

【删除链表中的节点】https://leetcode.cn/problems/delete-node-in-a-linked-list/description/

📕 示例

在这里插入图片描述

🖊 输入: head = [4, 5, 1, 9], node = 5
🖊 输出: [4, 1, 9]
🖊 解释: 指定链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9

在这里插入图片描述

🖊 输入: head = [4, 5, 1, 9], node = 1
🖊 输出: [4, 5, 9]
🖊 解释: 指定链表中值为 1 的第三个节点,那么在调用了你的函数之后,该链表应变为 4 -> 5 -> 9

在这里插入图片描述

🍀 分析

public class ListNode {int val;ListNode next;ListNode(int x) {val = x;}
}

🖊 每一个节点就是一个 ListNode 对象
🖊 val 属性存储了具体的数据
🖊 next 属性存储了一个节点的内存地址

public class Solution {public void deleteNode(ListNode node) {}
}

🖊 deleteNode(ListNode node) 方法中,参数node是要被"删除"的节点
🖊 在该题中能够获得到的已知条件就只有这个要被删除的节点 node

🖊 已知: 要被删除的节点 node
🖊 根据已知可以得到: ① 要被删除的节点往后的所有节点 node.next.next...(这里就考虑它的下一个节点 node.next);② 可以得到节点的 valnode


在这里插入图片描述

🖊 这里的删除第三个节点,并不是把该节点从内存中移除,而是让第三个节点的值不再是【1】,而是它的下一个节点的值【9】。并且第三个节点的 next 存储它的下一个节点的 next

在这里插入图片描述

在这里插入图片描述

💻 代码

class Solution {public void deleteNode(ListNode node) {// 用被删除节点的下一个节点的值覆盖被删除节点的值node.val = node.next.val;// 被删除节点的next指向它下一个节点的nextnode.next = node.next.next;}
}

二、反转链表

🌏 题目链接

【206.反转链表】https://leetcode.cn/problems/reverse-linked-list/description/

📕 示例

在这里插入图片描述

🖊 输入: head = [1, 2, 3, 4, 5]
🖊 输出: [5, 4, 3, 2, 1]

在这里插入图片描述

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

🖊 输入: head = []
🖊 输出: []

🍀 分析

class Solution {public ListNode reverseList(ListNode head) {}
}

🖊 reverseList(ListNode head) 方法只有一个参数 head(头指针),它指向了头节点

① 递归

在这里插入图片描述

👆 如上图所示,假如 reverseList 方法编写成功的话,reverseList(head) 方法调用后,该链表的头指针会指向方法调用之前的尾节点(如上图的 newHead
👆 原本的 head = [5, 4, 3, 2, 1] 也变成了 head = [1, 2, 3, 4, 5]

在这里插入图片描述

🖊 假如 reverseList(head.next) 调用成功,则整个链表如上图所示


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


public class Solution {public ListNode reverseList(ListNode head) {if (head == null || head.next == null) return head;// 递归ListNode newHead = reverseList(head.next);head.next.next = head;head.next = null;return newHead;}
}

② 迭代

在这里插入图片描述

🖊 已知条件就只有一个头指针 head,只能通过这个 head 进行反转


public class Solution {/*** 头插法(迭代)*/public ListNode reverseList(ListNode head) {if (head == null || head.next == null) return head;ListNode newHead = null;do {ListNode tmp = head.next;head.next = newHead;newHead = head;head = tmp;} while (head != null);return newHead;}
}

三、判断一个链表是否有环

🌏 题目链接

141.判断一个链表是否有环:https://leetcode.cn/problems/linked-list-cycle/description/

📕 示例

在这里插入图片描述

在这里插入图片描述

🍀 分析

🖊 使用快慢指针思想完成
🖊 fast 指针每次 next 两步;slow 指针每次 next 一步。若有环的话,快慢指针必然相遇
🖊 如果 fast 指向 null 或 fast.next 指向 null,则链表没有环

在这里插入图片描述

💻 代码

public class Solution {public boolean hasCycle(ListNode head) {if (head == null || head.next == null) return false;ListNode slow = head;ListNode fast = head.next;// 【fast == null || fast.next == null】都代表链表无环while (fast != null && fast.next != null) {slow = slow.next;fast = fast.next.next;if (slow == fast) return true;}return false;}
}

🍀 完整代码

http://www.yayakq.cn/news/902280/

相关文章:

  • 外贸 国外推广网站腾讯免费网站建设
  • 清远市网站建设烟台房地产网站建设
  • 湖南网站制作收费标准哈 做网站
  • 建设银行暑期招聘网站wordpress文件核对
  • 广州天河区网站建设网页设计模板素材营销型首页
  • 建设网站技术公司简介wordpress仿异次元
  • 论坛网站论坛网站建设建设seo排名工具给您好的建议下载官网
  • 南阳建网站公司苏州网站设计制作
  • 杭州认证网站建设网页制作需要哪些软件
  • 深圳建网站公司怎么选择乌兰察布盟建设银行网站
  • 艾瑞网站建设手机主页网站哪个好用
  • 崇明建设小学网站网页使用怎么做
  • 南沙开发区建设和交通局网站手机哪个网站好
  • 怎么给自己的网站做模版西安网站建设平台
  • 网站 运营工作如何做自己做的导航网站
  • 九江网站推广徽hyhyk1有个印度做网站的天天找我
  • 上海协会网站建设旅游网站建设那家好
  • 杭州租房网站建设网站建设空间怎么租用
  • wordpress文章被篡改灰色词seo
  • cmd iis重启单个网站网站色彩搭配
  • iis添加网站 别名网站备案后更换主机
  • 经典案例网站wordpress添加前台漂亮注册页面
  • 织梦dedecms多语言网站文章怎么黄骅市职教中心
  • 两学一做材料上哪个网站找商城网站建设公司爱问
  • 商城网站建设需要注意什么国内免费域名注册
  • 全球电商平台排名seo对网店的作用有哪些
  • 网站代运营多少钱wordpress 后台登陆不进去
  • 汕头市品牌网站建设公司魔贝课凡seo
  • 深圳市网站建设有补贴吗深圳市住房和建设局工程交易中心
  • 怎么做加盟美容院网站网站兼容代码