首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >2022-02-06:等差数列划分 II - 子序列。

2022-02-06:等差数列划分 II - 子序列。

作者头像
福大大架构师每日一题
发布2022-03-04 15:09:57
发布2022-03-04 15:09:57
2910
举报

2022-02-06:等差数列划分 II - 子序列。

给你一个整数数组 nums ,返回 nums 中所有 等差子序列 的数目。

如果一个序列中 至少有三个元素 ,并且任意两个相邻元素之差相同,则称该序列为等差序列。

例如,[1, 3, 5, 7, 9]、[7, 7, 7, 7] 和 [3, -1, -5, -9] 都是等差序列。

再例如,[1, 1, 2, 5, 7] 不是等差序列。

数组中的子序列是从数组中删除一些元素(也可能不删除)得到的一个序列。

例如,[2,5,10] 是 [1,2,1,2,4,1,5,10] 的一个子序列。

题目数据保证答案是一个 32-bit 整数。

示例 1:

输入:nums = [2,4,6,8,10]

输出:7

解释:所有的等差子序列为:

[2,4,6]

[4,6,8]

[6,8,10]

[2,4,6,8]

[4,6,8,10]

[2,4,6,8,10]

[2,6,10]

提示:

1 <= nums.length <= 1000

-2**31 <= nums[i] <= 2**31 - 1

力扣446。

答案2022-02-06:

dp[i]是一个map,i一定要做结尾。键是差值,值是个数。

时间复杂度:O( (logN) 平方)。

时间复杂度:O( (logN) 平方)。

代码用golang编写。代码如下:

代码语言:javascript
复制
import (
    "fmt"
    "math"
)

func main() {
    ret := numberOfArithmeticSlices([]int{2, 4, 6, 8, 10})
    fmt.Println(ret)
}

// 时间复杂度是O(N^2),最优解的时间复杂度
func numberOfArithmeticSlices(arr []int) int {
    N := len(arr)
    ans := 0
    maps := make([]map[int]int, 0)
    for i := 0; i < N; i++ {
        maps = append(maps, make(map[int]int))
        //  ....j...i(结尾)
        for j := i - 1; j >= 0; j-- {
            diff := arr[i] - arr[j]
            if diff <= math.MinInt64 || diff > math.MaxInt64 {
                continue
            }
            dif := diff
            count := maps[j][dif]
            ans += count
            maps[i][dif] += count + 1
        }
    }
    return ans
}

执行结果如下:

[左神java代码](https://github.com/algorithmzuo/coding-for-great-offer/blob/main/src/class49/Problem_0446_ArithmeticSlicesIISubsequence.java)

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-02-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 福大大架构师每日一题 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档