题解 | #链表内指定区间反转#
链表内指定区间反转
https://www.nowcoder.com/practice/b58434e200a648c589ca2063f1faf58c
package main import . "nc_tools" /* * type ListNode struct{ * Val int * Next *ListNode * } */ /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param head ListNode类 * @param m int整型 * @param n int整型 * @return ListNode类 */ func reverseBetween( head *ListNode , m int , n int ) *ListNode { // write code here if head ==nil || head.Next ==nil{ return head } //有一个空的指向前面的指针 dummy := &ListNode{Next:head} pre := dummy //计算pre. 记录好到反转前到一个元素 for i:=1;i<m;i++{ pre = pre.Next } cur := pre.Next //头插法;双指针操作两个元素-> 列表中的第二个元素插入到列表的顺序前面 for i:=m;i<n;i++{ temp := cur.Next //双指针,指向两个相邻的元素;对第二个元素要执行的操作是移动到列表的头部 //先处理尾部,把第二个元素移开 cur.Next = temp.Next //把第二个元素放到列表头部 temp.Next = pre.Next //pre是表示列表头 pre.Next = temp } return dummy.Next }#学习笔记#