leetcode_101 icon indicating copy to clipboard operation
leetcode_101 copied to clipboard

P42 413 Arithmetic Slices 解法有误

Open hkulyc opened this issue 3 years ago • 1 comments
trafficstars

int numberOfArithmeticSlices(vector<int>& nums) {
    int n = nums.size();
    if (n < 3) return 0;
    vector<int> dp(n, 0);
    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;
       }
}
    return accumulate(dp.begin(), dp.end(), 0);
}

参考解法最后一行只适用于整个数组都是等差数列的情况,但不适用于:

[1,2,3,5,4,5,6]

这种情况。

hkulyc avatar Aug 03 '22 08:08 hkulyc

您再跑一下?您给的test case我测了一下是过的。

changgyhub avatar Aug 25 '22 18:08 changgyhub