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

怎样用vs做简单网站国外网站推广公司

怎样用vs做简单网站,国外网站推广公司,网站建设参数,汕头澄海房价给你单链表的头指针 head 和两个整数 left 和 right &#xff0c;其中 left < right 。请你反转从位置 left 到位置 right 的链表节点&#xff0c;返回 反转后的链表 。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5], left 2, right 4 输出&#xff1a;[1,4,3,2…

给你单链表的头指针 head 和两个整数 left 和 right ,其中 left <= right 。请你反转从位置 left 到位置 right 的链表节点,返回 反转后的链表 。

示例 1:

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

示例 2:

输入:head = [5], left = 1, right = 1
输出:[5]

提示:

  • 链表中节点数目为 n
  • 1 <= n <= 500
  • -500 <= Node.val <= 500
  • 1 <= left <= right <= n

解法一

首先找到 m 的位置,记录两端的节点 left1 和 left2 。

然后每遍历一个节点,就倒置一个节点。

到 n 的位置后,利用之前的 left1 和 left2 完成连接。

为了完成链表的倒置需要两个指针 pre 和 head。为了少考虑边界条件,例如 m = 1 的倒置。加一个哨兵节点 dummy。

m = 2, n = 41 2 3 4 5 加入哨兵节点 d,pre 简写 p,head 简写 h0 1 2 3 4 5 往后遍历
^ ^
d h
p0 1 2 3 4 5 此时 h 指向 m 的位置,记录 p 和 h 为 l1 和 l2
^ ^ ^
d p h0  1  2 3 4 5 然后继续遍历
^  ^  ^
d  p  hl1  l20  1  2  3 4 5 开始倒置链表,使得 h 指向 p
^  ^  ^  ^
d  l1 p  hl2

当前状态用图形描述

倒转链表,将 h 的 next 指向 p,并且后移 p 和 h。

然后上边一步会重复多次,直到 h 到达 n 的位置。当然这道题比较特殊,上图 h 已经到达了 n 的位置。

此时,我们需要将 h 指向 p,同时将 l1 指向 h,l2 指向 h.next,使得链表接起来。

操作完成,将 dummy.next 返回即可。

public ListNode reverseBetween(ListNode head, int m, int n) {if (m == n) {return head;}ListNode dummy = new ListNode(0);dummy.next = head;int count = 0;ListNode left1 = null;ListNode left2 = null;ListNode pre = dummy;while (head != null) {count++;//到达 m,保存 l1 和 l2if (count == m) {left1 = pre;left2 = head;}// m 和 n 之间,倒转链表if (count > m && count < n) {ListNode temp = head.next;head.next = pre;pre = head;head = temp;continue;}//到达 nif (count == n) {left2.next = head.next;head.next = pre;left1.next = head;break;}//两个指针后移head = head.next;pre = pre.next;}return dummy.next;
}

时间复杂度:O(n)。

空间复杂度:O(1)。

http://www.bjxfkj.com.cn/article/105572.html

相关文章:

  • 花型图案设计网站网站优化排名软件
  • 找个做游戏的视频网站seo搜索引擎优化岗位要求
  • 手机网页传奇网站建设seo优化培训
  • 做国际网站有用吗国外网络推广
  • 厦门网站建设哪家不错c++培训班学费一般多少
  • 武汉网站营销优化源码西安优化外
  • 苹果钓鱼网站怎么做网络口碑推广公司
  • 什么软件能自己做网站chrome手机安卓版
  • 大良制作网站网站建设推广多少钱
  • 宜昌做网站要什么条件每日新闻最新消息
  • myeclipse做网站的步骤网站关键词排名优化工具
  • 微网站搭建教程app香港账号
  • php做网站要多久太原网站seo
  • 甘肃做网站找谁贵州seo技术培训
  • 如何做好网站建设和宣传seo关键词排名优化矩阵系统
  • 网页设计基础图片网站搜索引擎优化情况怎么写
  • 杭州公司注册虚拟地址自然搜索优化
  • 上海集团有限公司南京seo公司
  • 动态网站建设视频教程优化方案的格式及范文
  • 微信小程序开发技术正规网站优化哪个公司好
  • 安徽省建设网站周口网站建设公司
  • 安徽阜阳网站建设公司郑州网站设计
  • 网站广告下悬浮代码怎么做杭州网站关键词排名
  • 临清网站开发东莞关键词排名推广
  • 开州快速建网站天津网站建设
  • 自己制作的网站模板以后可以修改吗怎样做一个网页
  • 企业建设网站个人总结深圳做seo有哪些公司
  • 域名服务器如何申请网站优化推广软件
  • 潍坊网站建设 潍坊做网站友情链接出售平台
  • 个人网站制作dw新浪网今日乌鲁木齐新闻