力扣热题100 k个一组反转链表题解

题目:

代码:

Go 复制代码
func reverseKGroup(head *ListNode, k int) *ListNode {
	cur := head
	for i := 0; i < k; i++ {
		if cur == nil {
			return head
		}
		cur = cur.Next
	}
	newHead := reverse(head, cur)
	head.Next = reverseKGroup(cur, k)
	return newHead
}

func reverse(start, end *ListNode) *ListNode { //翻转
	var pre *ListNode
	cur := start
	for cur != end {
		nex := cur.Next
		cur.Next = pre
		pre = cur
		cur = nex
	}
	return pre
}
相关推荐
你好~每一天1 分钟前
未来3年,最值得拿下的5个AI证书!
数据结构·人工智能·算法·sqlite·hbase·散列表·模拟退火算法
杰克尼5 分钟前
3. 分巧克力
java·数据结构·算法
zmzb010337 分钟前
C++课后习题训练记录Day39
数据结构·c++·算法
Ayanami_Reii1 小时前
进阶数学算法-取石子游戏(ZJOI2009)
数学·算法·游戏·动态规划·区间dp·博弈论
一只小小汤圆1 小时前
已知圆弧的起点、终点、凸度 求圆弧的圆心
算法
丸码2 小时前
Java HashMap深度解析
算法·哈希算法·散列表
算法与编程之美2 小时前
Java数组动态扩容
java·开发语言·python·算法
2301_764441332 小时前
三维建筑非法入侵情景推演
python·学习·算法
唯道行2 小时前
计算机图形学·19 Shadings in OpenGL
人工智能·算法·计算机视觉·几何学·计算机图形学·opengl
初夏睡觉3 小时前
全排列题解
算法·深度优先·图论