用C ++修补数组
为了解决这个问题,我们将遵循以下步骤-
req:=1,i:=0,ret:=0
当req<=n时,执行-
需求=需求+需求
增加ret1
req=req+数字[i]
使我增加1
如果i<nums和nums[i]<=req的大小,则,
除此以外
返回ret
示例
让我们看下面的实现以更好地理解-
#include <bits/stdc++.h>
using namespace std;
class Solution {
public:
int minPatches(vector<int>& nums, int n) {
long long int req = 1;
int i = 0;
int ret = 0;
while(req <= n){
if(i < nums.size() && nums[i] <= req){
req += nums[i];
i++;
} else {
req += req;
ret++;
}
}
return ret;
}
};
main(){
Solution ob;
vector<int> v = {1,4};
cout << (ob.minPatches(v, 7));
}输入值
{1,4}输出结果
1
热门推荐
1 祝福语简短古诗词
10 祝寿时祝福语简短精辟
11 端午发给客户祝福语简短
12 过节文案成语祝福语简短
13 新郎表白成语祝福语简短
14 新疆新年祝福语大全简短
15 给宝贝开学祝福语简短
16 三十三句祝福语简短
17 新年给妹妹祝福语简短
18 空军大学开学祝福语简短