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

成都广告设计制作公司搜索引擎优化论文

成都广告设计制作公司,搜索引擎优化论文,网站开发用例图,班级网页设计图片【力扣】19. 删除链表的倒数第 N 个结点 给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。 示例 1: 输入:head [1,2,3,4,5], n 2 输出:[1,2,3,5] 示例 2: 输入:head [1], n…

【力扣】19. 删除链表的倒数第 N 个结点

给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。

示例 1:
输入:head = [1,2,3,4,5], n = 2
输出:[1,2,3,5]

在这里插入图片描述
示例 2:
输入:head = [1], n = 1
输出:[]

示例 3:
输入:head = [1,2], n = 1
输出:[1]

提示
链表中结点的数目为 sz
1 <= sz <= 30
0 <= Node.val <= 100
1 <= n <= sz

题解

方法一:两次遍历

  • 先遍历一次链表,求出链表的总长度。
  • 根据总长度 length 的值-n,就算出需要再遍历多少个节点,找到要删除的节点的前一个节点 x。
  • 将 x 节点的 next 指针指向下下一个节点就可以删除节点了。
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 Solution {public ListNode removeNthFromEnd(ListNode head, int n) {if (head == null || n <= 0) {return head;}//增加一个特殊节点,方便边界处理ListNode dummyNode = new ListNode(-1);dummyNode.next = head;ListNode cur = dummyNode;//第一次遍历,计算链表总长度int length = 0;while (cur.next != null) {cur = cur.next;++length;}//如果链表总长度小于n,那就直接返回if (length < n) {return head;}//计算第二次遍历多少个节点int num = length - n;cur = dummyNode;//第二次遍历,找到要删除节点的前一个节点while (num > 0) {cur = cur.next;--num;}//删除节点,并返回cur.next = cur.next.next;return dummyNode.next;}
}

方法二:一次遍历(快慢指针)

需要两个指针 slow 和 fast。fast 指针先走 n 步,接着 slow 和 fast 指针同时往前走,当 fast 指针走到链表末尾时,slow 指针就正好走到要删除的节点的前一个位置了,最后 slow 节点的 next 指针指向下下一个节点,就可以完成删除操作。

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 Solution {public ListNode removeNthFromEnd(ListNode head, int n) {//增加一个特殊节点方便边界判断ListNode dummyNode = new ListNode(-1);dummyNode.next = head;ListNode slow = dummyNode;ListNode fast = dummyNode;//第一个循环,fast 指针先往前走n步while (n > 0 && fast != null) {fast = fast.next;n--;}// n > 链表length,fast走n步到尾了,于是后面的判断就不用做了,直接返回if (fast == null) {return head;}//第二次,fast、slow指针一起走//当遍历结束时,slow指针就指向要删除的节点的前一个位置while (fast.next != null) {slow = slow.next;fast = fast.next;}//删除节点并返回slow.next = slow.next.next;return dummyNode.next;}
}
http://www.15wanjia.com/news/6738.html

相关文章:

  • 电商网站模板html合肥seo推广外包
  • 长宁区网站建设网站网站域名ip查询
  • 医疗网站平台建设方案网站开通
  • 如何自己做网站赚钱磁力猫官网cilimao
  • 如何做视频会员网站企业互联网推广
  • 湖北营销型网站建设价格市场营销十大经典案例
  • 网站上哪个做相片书好域名注册商
  • 专门做图片剪影的网站宁波seo排名优化哪家好
  • 网站加强阵地建设与管理全网seo优化电话
  • 2免费做网站google play下载安装
  • 丰台做网站公司常见网络营销推广方法
  • 哪些网站可以做兼职设计师深圳网站开发制作
  • 四川省示范校建设网站seo整站优化报价
  • 网站建设淘宝客模板seo外包公司如何优化
  • 可以做ppt的网站有哪些seo网站排名查询
  • 丹东抖音seo精英南宁seo全网营销
  • 私自使用他人图片做网站宣传留号码的广告网站
  • 注册网站怎么做网站扬州百度seo公司
  • 京东淘宝网站是怎么做的网络seo优化平台
  • 男女做暖暖其他网站seo搜索引擎优化哪家好
  • 公司网站营销百度明星人气榜入口
  • 网站开发 实训 报告免费宣传平台
  • 个人备案 做网站搜索引擎广告图片
  • 石材做网站千锋培训学费多少钱
  • 沈阳模板建站定制网址查询域名
  • 免费源码资源分享网seo云优化方法
  • 外贸商城网站制作公司广告设计网站
  • 哪个企业做网站全网整合营销外包
  • 响应式网站 宽度百度地图优化
  • 网站的ab测试怎么做app注册推广任务平台