413. 等差数列划分

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

例如,[1,3,5,7,9]、[7,7,7,7] 和 [3,-1,-5,-9] 都是等差数列。
给你一个整数数组 nums ,返回数组 nums 中所有为等差数组的 子数组 个数。

子数组 是数组中的一个连续序列。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/arithmetic-slices
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

class Solution {
    public int numberOfArithmeticSlices(int[] nums) {
        if (nums == null || nums.length < 3) {
            return 0;
        }
        int ans = 0;
        int preNum = 2;
        int pre = nums[1] - nums[0];
        for (int i = 2; i < nums.length; ++i) {
            if (nums[i] - nums[i - 1] == pre) {
                preNum++;
                ans += preNum - 2;
            } else {
                preNum = 2;
                pre = nums[i] - nums[i - 1];
            }
        }
        return ans;
    }
}
上一篇:LeetCode:最大子数组和


下一篇:CF1253B - Silly Mistake(贪心+构造性算法+提高级)