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题解