如果一个数列 至少有三个元素 ,并且任意两个相邻元素之差相同,则称该数列为等差数列。
例如,[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;
}
}