本文主要是介绍leetcode 413 等差数列划分 动态规划 简单递推,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
// 递推, 每个数除了第一个,都可形成长度为2的序列
// 如果差值和之前相同, 那么序列加一, 否则长度为2
// 倒着找最长的, 每段长度L的序列数为(L - 2) * (L - 1) / 2class Solution {
public:int numberOfArithmeticSlices(vector<int>& nums) {int n = nums.size();vector<int> dp(n);if (n <= 2) return 0;dp[0] = 1;dp[1] = 2;for (int i = 2; i < n; i++) {if (nums[i] - nums[i - 1] == nums[i - 1] - nums[i - 2]){dp[i] = dp[i - 1] + 1;}else {dp[i] = 2;}}int pre = -1;int cnt = 0;for (int i = n - 1; i > 1; i --) {if (dp[i] > pre && dp[i] > 2) {cnt += (dp[i] - 2) * (dp[i] - 1) / 2;}pre = dp[i];}return cnt;}
};
这篇关于leetcode 413 等差数列划分 动态规划 简单递推的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!