2022-4-18 Leetcode 413. 等差数列划分

在这里插入图片描述
在这里插入图片描述

class Solution {
    
    
public:
    int numberOfArithmeticSlices(vector<int>& nums) {
    
    
        int n = nums.size();
        if (n == 1) {
    
    
            return 0;
        }

        int d = nums[0] - nums[1], t = 0;
        int ans = 0;
        // 因为等差数列的长度至少为 3,所以可以从 i=2 开始枚举
        for (int i = 2; i < n; ++i) {
    
    
            if (nums[i - 1] - nums[i] == d) {
    
    
                ++t;
            }
            else {
    
    
                d = nums[i - 1] - nums[i];
                t = 0;
            }
            ans += t;
        }
        return ans;
    }
};

作者:LeetCode-Solution
链接:https://leetcode-cn.com/problems/arithmetic-slices/solution/deng-chai-shu-lie-hua-fen-by-leetcode-so-g7os/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

猜你喜欢

转载自blog.csdn.net/weixin_51187533/article/details/124241297