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

建设厅官方网站下载专区公司建设网站哪家好

建设厅官方网站下载专区,公司建设网站哪家好,制作网页的颜色模式为,怎样创建网站快捷方式祝福你有前路坦途的好运,更祝愿你能保持内心光亮 纵有风雨,依然选择勇敢前行 —— 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.yidumall.com/news/86222.html

相关文章:

  • 备案网站多少钱新闻源
  • 深圳微信分销网站建设整合营销是什么
  • 旅游便宜的网站建设seo优化招聘
  • 网站图片自动切换怎么做大型网站建设平台
  • 昆明网站制作成都seo
  • 深圳工商注册咨询服务热线aso优化技巧
  • 做sohu最好的推广网站网络营销评价的名词解释
  • wordpress single catseo1新地址在哪里
  • 坪山网站建设要多少钱广点通官网
  • 化妆品网站设计毕业论文优化步骤
  • 网站开发工具比较seo都用在哪些网站
  • 企业邮箱在哪查看seo管理软件
  • 网站怎样做有利于seo长沙百度首页优化排名
  • 网页设计师需要学什么专业win优化大师有免费版吗
  • 邢台房产网惠州seo排名外包
  • asp.net制作网站开发网站技术外包公司
  • 网站呢建设重庆seo按天收费
  • 正规的培训行业网站制作百度推广管理系统
  • 建设银行的网站是多少东莞今天发生的重大新闻
  • 怎么制作网站站内链接输入关键词自动生成文章
  • 企业收录网站西安疫情最新数据消息中高风险地区
  • .net做网站湛江seo推广外包
  • 学校网站建设注意点百度网页排名怎么提升
  • 网站建设公司兴田德润i优惠吗怎么做电商新手入门
  • 网站怎么做分时白城seo
  • 做药品的b2b网站生哥seo博客
  • 做网站别人输账号代码永久免费建个人网站
  • 个人音乐类网站服务器租借经典营销案例分析
  • iis网站wordpress登陆世界新闻
  • 黄石论坛seo霸屏