413. 等差数列划分

2022/1/11 6:05:03

本文主要是介绍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;
    }
}


这篇关于413. 等差数列划分的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程