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

卢湾品牌网站建设优化教程

卢湾品牌网站建设,优化教程,树莓派可以做网站空间吗,如何增加网站pr值祝福你有前路坦途的好运,更祝愿你能保持内心光亮 纵有风雨,依然选择勇敢前行 —— 24.9.22 203. 移除链表元素 给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val val 的节点,并返回 新的头节点 。 示…

祝福你有前路坦途的好运,更祝愿你能保持内心光亮

纵有风雨,依然选择勇敢前行

                                                                        —— 24.9.22

203. 移除链表元素

给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点 。

示例 1:

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

示例 2:

输入:head = [], val = 1
输出:[]

示例 3:

输入:head = [7,7,7,7], val = 7
输出:[]

提示:

  • 列表中的节点数目在范围 [0, 104] 内
  • 1 <= Node.val <= 50
  • 0 <= val <= 50

方法1

思路

定义哨兵节点,定义两个指针,指针1指向头结点,指针2指向头结点的下一个结点,进行循环,比较指针2指向的结点是否等于要删除的结点,如果等于,则接着后移进行遍历,直至指针2指向空,遍历结束

/*** Definition for singly-linked list.* public class ListNode {*     int val;*     ListNode next;*     ListNode() {}*     ListNode(int val) { this.val = val; }*     ListNode(int val, ListNode next) { this.val = val; this.next = next; }* }*/
class Solution {public static ListNode removeElements(ListNode head, int val) {ListNode s = new ListNode(-1,head);ListNode p1 = s;ListNode p2 = s.next;while (p2 != null) {if (p2.val == val) {p1.next = p2.next;p2 = p2.next;}else {p1 = p2;p2 = p2.next;}}return s.next;}
}

方法2

思路

递归函数负责返回:从当前节点开始,完成删除的的链表

        1.若当前节点与目标相等,应该返回下一个节点递归结果

        2.若当前节点与目标不等,应该返回当前节点,但当前节点的 next 应该更新

/*** Definition for singly-linked list.* public class ListNode {*     int val;*     ListNode next;*     ListNode() {}*     ListNode(int val) { this.val = val; }*     ListNode(int val, ListNode next) { this.val = val; this.next = next; }* }*/
class Solution {public ListNode removeElements(ListNode head, int val) {if (head == null) {return head;}head.next = removeElements(head.next, val);return head.val == val ? head.next : head;}
}

完整代码

ListNode类定义

package Day9ListPractice;public class ListNode {public int val;public ListNode next;public ListNode(int val, ListNode next) {this.val = val;this.next = next;}// 可变长参数public static ListNode of(int...numbers) {ListNode head = new ListNode(0, null);ListNode current = head;for (int number : numbers) {current.next = new ListNode(number, null);current = current.next;}return head;}@Overridepublic String toString() {StringBuilder sb = new StringBuilder(64);sb.append("[");ListNode p = this;while (p != null) {sb.append(p.val);if (p.next != null) {sb.append(",");}p = p.next;}sb.append("]");return sb.toString();}
}

方法函数 

public class LeetCode203RemoveListData {// 方法1 迭代public static ListNode removeElements1(ListNode head, int val) {ListNode s = new ListNode(-1,head);ListNode p1 = s;ListNode p2 = s.next;while (p2 != null) {if (p2.val == val) {p1.next = p2.next;p2 = p2.next;}else {p1 = p2;p2 = p2.next;}}return s.next;}// 方法2 递归public ListNode removeElements2(ListNode head, int val) {if (head == null) {return head;}head.next = removeElements2(head.next, val);return head.val == val ? head.next : head;}public static void main(String[] args) {ListNode head = ListNode.of(1,2,3,4,5,6,7,8);System.out.println(head);System.out.println(new LeetCode203RemoveListData().removeElements1(head, 1));System.out.println(new LeetCode203RemoveListData().removeElements2(head, 7));}
}

http://www.ds6.com.cn/news/102446.html

相关文章:

  • 模板网站和定制网站的区别是什么网络营销教程
  • 做模型的网站谷歌chrome官网
  • linux做网站哪个版本好我想在百度上发布广告怎么发
  • mip网站设计秘密入口3秒自动进入
  • 张家港网站设计制作早晨设计qq群怎么优化排名靠前
  • 网站更换图片之类的怎么做百度贴吧广告投放价格
  • 网站建设人才调研百度收录入口在哪里查询
  • 网站服务类型有哪些好看的友情链接代码
  • 在网站后台为什么不显示百分号2345浏览器主页网址
  • 台州公司做网站灰色关键词排名优化
  • 领卷网站怎么做的设计网站一般多少钱
  • 响应式网站开发的设计原则网络广告的优势有哪些
  • 有招聘网站策划的吗seox
  • 做自己的网站后台云南seo公司
  • 建设工程用地批准手续在哪个网站长沙网站推广公司排名
  • 做系统软件的网站百度热搜榜排名今日头条
  • 北京行业网站建设带佣金的旅游推广平台有哪些
  • 可以做网站引导页的页面北大青鸟软件开发培训学费多少
  • 做网站后台用什么写上海牛巨仁seo
  • 一开始用php做网站龙华线上推广
  • 一般做个网站多少做网站多少钱湖南网站建设推荐
  • 医疗美容手机网站建设app定制开发
  • 东莞做汽车有没有买票的网站php视频转码
  • 北京大兴最专业的网站建设公司自动seo优化
  • 网站策划书撰写收录网站的平台有哪些
  • 网站盗号怎么做关键词优化的发展趋势
  • 嘉兴网站排名公司安卓优化大师旧版本下载
  • 防红短网址在线生成湛江seo网站管理
  • 网站开发使用的语言有哪些湖北网络营销网站
  • 简洁手机导航网站模板下载安装杭州seo搜索引擎优化