这道题标记为简单,本以为遍历完就够了,结果报错了。[3,4,2,3]这种情况和其他的还不一样,我们需要修改数字,但是相对于i来说,当i = 1时,我们应该优先考虑把 i - 1 调小到 >= i - 2并且 <= i。同样尽量不去修改 i。我们需要修改i-1,而不是i,因为i具体我们还不知道,当 i > 1 且 i < i - 2 时,我们无法调整 i - ] ,我们只能调整i到 i - 1。
N = len(nums)
count = 0
for i in range(1, N):
if nums[i] < nums[i - 1]:
count += 1
if i == 1 or nums[i] >= nums[i - 2]:
nums[i - 1] = nums[i]
else:
nums[i] = nums[i - 1]
return count <= 1