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

301网站目录中国新闻最新消息

301网站目录,中国新闻最新消息,logo设计在线生成免费免费设计logo,使用下载的整站asp源代码建设自己的私人网站需要注意哪些1、算法思路 讲一下设置虚拟头节点的那个方法,设置一个新节点指向原来链表的头节点,这样我们就可以通过判断链表的当前节点的后继节点值是不是目标删除值,来判断是否删除这个后继节点了。如果不设置虚拟头节点,则需要将头节点和后…

1、算法思路

讲一下设置虚拟头节点的那个方法,设置一个新节点指向原来链表的头节点,这样我们就可以通过判断链表的当前节点的后继节点值是不是目标删除值,来判断是否删除这个后继节点了。如果不设置虚拟头节点,则需要将头节点和后面的节点分开来讨论,代码会复杂一点。

2、Java代码实现

package listnodes;//Definition for singly-linked list.
class ListNode {int val;ListNode next;ListNode() {}ListNode(int val) { this.val = val; }ListNode(int val, ListNode next) { this.val = val; this.next = next; }
}public class RemoveElements {public static void main(String[] args) {//构造链表
//        int[] nums = new int[]{1,2,6,3,4,5,6};
//        int[] nums = new int[]{7,7,7,7};int[] nums = new int[]{1,2,2,1};ListNode head = null;for (int i = nums.length - 1; i >= 0; i--) {ListNode node = new ListNode(nums[i]);if(head != null){node.next = head;}head = node;}//处理链表Solution sol = new Solution();
//        ListNode resNode = sol.removeElements(head, 6);//[1,2,3,4,5]
//        ListNode resNode = sol.removeElements(head, 7);//[]ListNode resNode = sol.removeElements(head, 2);//[1, 1]//遍历链表并打印StringBuilder sb = new StringBuilder("[");while(resNode != null){if(sb.length() != 1) sb.append(", ");sb.append(resNode.val);resNode = resNode.next;}sb.append("]");System.out.println(sb);}
}// 递归法
//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;
//    }
//}// 头结点是否删除最后再考虑
//class Solution {
//    public ListNode removeElements(ListNode head, int val) {
//        ListNode pre = head;
//        while(pre != null && pre.next != null){
//            if(pre.next.val == val){
//                //跳过当前节点的后一个节点赋值给当前节点的前一个节点的next,相当于删除当前节点
//                pre.next = pre.next.next;
//            }else{
//                pre = pre.next;
//            }
//        }
//        pre = head;
//        while(pre != null && pre.val == val){
//            pre = pre.next;
//        }
//        return pre;
//    }
//}// 设置一个虚拟头结点,这样代码更简单
class Solution {public ListNode removeElements(ListNode head, int val) {ListNode temp = new ListNode(0);temp.next = head;ListNode pre = temp;while(pre.next != null){if(pre.next.val == val){//跳过当前节点的后一个节点赋值给当前节点的前一个节点的next,相当于删除当前节点pre.next = pre.next.next;}else{pre = pre.next;}}return temp.next;}
}

3、完整题目

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, 10^4] 内
  • 1 <= Node.val <= 50
  • 0 <= val <= 50
http://www.yayakq.cn/news/594560/

相关文章:

  • 做网站需要哪些准备怎样在手机上建立自己的网站
  • 建立自己的网站预付做网站定金如何
  • 高清做爰片免费观看网站个人网站建设基础与实例
  • 网站qq登录 开发企业年金在哪里查询
  • 网站设计是什么专业硬件开发外包平台
  • 网站设计怎么划分块一个新手怎么做推广
  • 网站开发公司名字手机软件分类
  • 专业网站建设科技公司广州公司营销型网站建设
  • 影响网站排名原因深圳 SEO 网站建设 哪里学
  • 试管婴儿网站建设通过招聘网站如何做背景调查
  • 怎么做自己的淘客网站有什么兼职做设计的网站好
  • 公司网站建设开发维护工作总结wordpress后台安全
  • 网站html源码下载网站建设流程时间表
  • 北京做手机网站的公司青海省网站建设公司
  • 江苏省品牌专业建设网站毕业设计网站开发的中期报告
  • 凡科做网站怎么样吉林省建设安全信息网官网
  • 限时抢购网站源码东莞大岭山中学
  • 平面设计软件下载网站河北建设网网站
  • 富阳网站建设怎样建设公司官网介绍
  • 领硕网站seo优化哪个学校的计算机专业最好
  • 网站上内容列表怎么做的泰州seo排名扣费
  • 网站建设设计费用自己做网站的好处
  • 企业网站建设优势深圳网页设计科技有限公司
  • 网站做qq登录界面wordpress 修改导航
  • 做网站平面模板是啥意思市场营销推广策划方案
  • 福建省建设厅网站 登录123网址导航
  • 网站网站建设费进什么科目郴州网站建设软件定制开发平台
  • 国外服装网站我做的网页怎么是危险网站
  • 企业做网站上海足球比赛直播平台app
  • 如何在手机上建立自己的网站济南官网seo推广