题解 | #删除链表峰值#

删除链表峰值

https://www.nowcoder.com/practice/30a06e4e4aa549198d85deef1bab6d25

package main

// import "fmt"
import . "nc_tools"

/*
 * type ListNode struct{
 *   Val int
 *   Next *ListNode
 * }
 */

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 *
 * @param head ListNode类
 * @return ListNode类
 */
func deleteNodes(head *ListNode) *ListNode {
	// write code here
	pre := head
	cur := head.Next
	for cur.Next != nil {
		if cur.Val > cur.Next.Val && cur.Val > pre.Val {
			delete(head, cur.Val)
		}
		pre = cur
		cur = cur.Next
	}
	return head
}

func delete(head *ListNode, target int) {
	tmp := head
	pre := &ListNode{Next: tmp}
	for tmp != nil {
		if tmp.Val == target {
			if tmp.Next == nil {
				tmp = nil
				break
			}
			pre.Next = tmp.Next
			tmp = nil
			break
		}
		pre = pre.Next
		tmp = tmp.Next
	}
}

全部评论

相关推荐

02-16 13:52
门头沟学院 Java
给🐭🐭个面试机会吧:嘿,mvbatis
点赞 评论 收藏
分享
你包有offer的:我面了10面才进去
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务