题解 | #牛群的重新排列#
牛群的重新排列
https://www.nowcoder.com/practice/5183605e4ef147a5a1639ceedd447838?tpId=354&tqId=10590581&ru=/exam/oj/ta&qru=/ta/interview-202-top/question-ranking&sourceUrl=%2Fexam%2Foj%2Fta%3FtpId%3D354
知识点:链表反转
解题思路:先遍历找到反转的开始,然后调用普通的反转函数(万能模版)即可
package main
import . "nc_tools"
/*
* type ListNode struct{
* Val int
* Next *ListNode
* }
*/
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param head ListNode类
* @param left int整型
* @param right int整型
* @return ListNode类
*/
func reverseBetween( head *ListNode , left int , right int ) *ListNode {
// write code here
newHead:=&ListNode{0,head}
pre := newHead
for i:=0;i<left-1;i++{
pre = pre.Next
}
cur := pre.Next
pre.Next=reverse(cur, right-left+1)
return newHead.Next
}
func reverse(a *ListNode,k int)*ListNode{
pre,cur,next:=(*ListNode)(nil),a,a
for i:=0;i<k;i++{
next = cur.Next
cur.Next = pre
pre,cur = cur,next
}
a.Next =next
return pre
}
