网站首页 > 精选教程 正文
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编写。代码如下:
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)
猜你喜欢
- 2025-05-23 C# 动态数组(ArrayList)
- 2025-05-23 C# 7.0中的Discard 变量:简化代码的利器
- 2025-05-23 JS数组过滤元素的方法
- 2025-05-23 JavaScript去除数组重复元素的几种方法
- 2025-05-23 【HarmonyOS Next之旅】ArkTS语法(一)
- 2025-05-23 C/C++编程笔记:帮你整理了"数组"的知识点!赶紧收藏
- 2025-05-23 Java 基础(四)集合源码解析 List
- 2025-05-23 Java中数组的声明和初始化方法
- 2025-05-23 数组、链表、队列和栈,四大基础数据结构详解
- 2025-05-23 最快清除数组空值?分享 1 段优质 JS 代码片段!
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)