网站服务器 502,app定制软件开发哪家好,抚州哪里有做企业网站的公司,东莞做营销网站建设665. 非递减数列
给你一个长度为 n 的整数数组 nums #xff0c;请你判断在 最多 改变 1 个元素的情况下#xff0c;该数组能否变成一个非递减数列。
我们是这样定义一个非递减数列的#xff1a; 对于数组中任意的 i (0 i n-2)#xff0c;总满足 nums[i] …665. 非递减数列
给你一个长度为 n 的整数数组 nums 请你判断在 最多 改变 1 个元素的情况下该数组能否变成一个非递减数列。
我们是这样定义一个非递减数列的 对于数组中任意的 i (0 i n-2)总满足 nums[i] nums[i 1]。
示例 1:
输入: nums [4,2,3] 输出: true 解释: 你可以通过把第一个 4 变成 1 来使得它成为一个非递减数列。
示例 2:
输入: nums [4,2,1] 输出: false 解释: 你不能在只改变一个元素的情况下将其变为非递减数列。
这题直接使用先改后验法就可以了这种问题基本都是这么做的一次修改检索是否符合条件。 解题代码如下
bool checkPossibility(int* nums, int numsSize){for(int i0;inumsSize-1;i){if(i1){if(nums[i]nums[i1]nums[i1]nums[i-1]){nums[i]nums[i1];break;}if(nums[i]nums[i1]nums[i1]nums[i-1]){nums[i1]nums[i];break;}}if(i0){if(nums[i]nums[i1]){nums[i]nums[i1];break;}}}for(int i0;inumsSize-1;i){printf(%d ,nums[i]);}for(int i0;inumsSize-1;i){if(nums[i]nums[i1]){return false;}}return true;}