题解 | #反转链表#

反转链表

https://www.nowcoder.com/practice/75e878df47f24fdc9dc3e400ec6058ca

package main
import . "nc_tools"
/*
 * type ListNode struct{
 *   Val int
 *   Next *ListNode
 * }
 */

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param head ListNode类 
 * @return ListNode类
*/
func ReverseList( head *ListNode ) *ListNode {
    // 首先判断如果链表为空或者只有一个元素,直接返回即可
    if head == nil || head.Next == nil {
		return head
	}
	var prev *ListNode // 用prev记录需要前向指向的节点
	current := head // current 记录当前操作的节点
	for current != nil {
		// 修改指向
		next := current.Next // 记录当前节点的下一个节点,可以向后遍历
		// 剩下就是修改指向,然后向后遍历
		current.Next = prev
		prev = current
		current = next
	}
	return prev
}

全部评论

相关推荐

蚂蚁 基架java (n+6)*16 签字费若干
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-27 10:48
点赞 评论 收藏
分享
我在朝九晚六双休的联想等你:如果我是你,身体素质好我会去参军,然后走士兵计划考研211只需要200多分。
点赞 评论 收藏
分享
尊嘟假嘟点击就送:加v细说,问题很大
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务