题意
定义一个数组为“稳定的”,当且仅当数组相邻的两个元素之差的绝对值不超过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)
}

京公网安备 11010502036488号