链表分组反转python_链表中的节点每k个一组翻转

方法一:利用栈结构的解法,时间复杂度O(n),空间复杂度O(k)

1:从左到右遍历链表,如果栈的大小不等于k,就将节点不断压入栈中

2:当栈的大小第一次达到k时,说明第一次凑齐了k个节点进行逆序,从栈中依次弹出

这些节点,并根据弹出顺序依次链接,这一组逆序完成后,需要记录一下新的头部,

同时第一组的最后一个节点(原来是头结点)应该链接下一个节点。

3:步骤2之后,当栈的大小每次达到k时,说明又凑齐了一组应该进行逆序的节点,从

栈中依次弹出这些节点,并根据弹出的顺序重新链接。这一组逆序完成后,该组的第一

个节点(原来是该组最后一个节点)应该被上一组的最后一个节点链接上,这一组的最

后一个节点(原来是该组第一个节点)应该链接下一个节点。然后继续去凑下一组,直

到链表被遍历完成。

第一种方法的空间复杂度略高,我们看第二种解法:

方法二:不需要栈结构,直接在链表中调整。时间复杂度O(n),空间复杂度O(1),是符合

题目要求的解法。

//实现反转链表的指定区间,反转start-end之间的节点,将反转后链表的头结点和尾节

//点保存,记作newStart和newEnd

void reverseList(ListNode *start, ListNode *end,

ListNode *&newStart, ListNode *&newEnd){

ListNode *pNode

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值