15天大厂真题带刷 - ZT31游游的最长稳定子数组

游游的最长稳定子数组

https://www.nowcoder.com/practice/ea7098b7960348f6915e252f0c4debcc

题意

定义一个数组为“稳定的”,当且仅当数组相邻的两个元素之差的绝对值不超过1。求出该数组的最长的“稳定的”连续子数组的长度

思路

一次遍历即可,维护两个变量,其中ans表示答案,tmp表示当前的稳定的连续子数组的长度,如果第i个元素可以和第i-1个元素构成稳定子数组,tmp加1;否则,维护ans。注意遍历后还要更新下ans

Go代码

package main

import (
    "fmt"
)
func abs(a int) int {
	if a < 0 {
		return -a
	}
	return a
}
func max(a, b int) int {
	if a > b {
		return a
	}
	return b
}
func main() {
    var n int 
    fmt.Scan(&n)
    ans,tmp := 1,1
    a := make([]int,n+1)
    for i := 1; i <= n; i ++ {
        fmt.Scan(&a[i])
    }
    for i := 2; i <= n; i ++ {
        if abs(a[i]-a[i-1]) <= 1 {
            tmp ++
        }else{
            ans = max(ans,tmp)
            tmp = 1 
        }
    }
    ans = max(ans,tmp)
    fmt.Println(ans)
}

#牛客创作赏金赛#
15天大厂真题带刷Go题解 文章被收录于专栏

15天大厂真题带刷Golang题解

全部评论

相关推荐

2024-11-29 11:43
河南科技大学 Java
铁锈不腻玩家:下面那个袁先生删了,问他怎么回事,头像都换不明白
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务