62 贪心算法按要求补齐数组

给定一个已经排序的正整数数组nums,和一个正整数n,从[1,n]取件中选取任意个数字到nums中,使得[1,n]区间内的任何数字都可以用nums中某几个数字的来表示,请输出满足上述条件的最少需要补充的数字个数。

问题分析:该题让找出任何数字都可以组成n,且数组时排序的,我们假设前一个数字所能组成的数字范围是[1,total],那么加上一个数nums[k],则范围变为[1,total]并上[nums[k],nums[k+total]],如果nums[k]<total,则直接可以构成[1,nums[k]+total]这个范围,则表示使用nums数组是连续的,不需要添加新的数字,如果不可以,表明nums[k]已经断开了连接,需要添加total+1这个数字,使得范围变为[1,2*toal+1];

public int complement(int []nums,int n)
{
int count=0;
int total=0;
int k=0;
while(total<n)
{
if(total+1=>nums[k])
{
total=nums[k]+total;
}else
{
total+=total+1;
count++;
}
k++;
}
​​​​​​​return count;
}

相关推荐

  1. 62 贪心算法要求数组

    2023-12-24 15:54:02       56 阅读
  2. 算法训练营day27(),贪心算法1

    2023-12-24 15:54:02       46 阅读
  3. 算法训练营day28(), 贪心算法2

    2023-12-24 15:54:02       54 阅读
  4. 构造数字贪心算法

    2023-12-24 15:54:02       50 阅读
  5. 61 贪心算法解救生艇问题

    2023-12-24 15:54:02       52 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-24 15:54:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-24 15:54:02       101 阅读
  3. 在Django里面运行非项目文件

    2023-12-24 15:54:02       82 阅读
  4. Python语言-面向对象

    2023-12-24 15:54:02       91 阅读

热门阅读

  1. C++函数默认值的用法

    2023-12-24 15:54:02       50 阅读
  2. 蝴蝶算法优化 Matlab 实现

    2023-12-24 15:54:02       62 阅读
  3. 用Python实现乒乓球游戏

    2023-12-24 15:54:02       55 阅读
  4. vivado I/O延迟约束

    2023-12-24 15:54:02       60 阅读
  5. android 13.0 Launcher3定制folder文件夹16宫格实现二

    2023-12-24 15:54:02       52 阅读
  6. R语言使用scitb包10分钟快速绘制论文基线表

    2023-12-24 15:54:02       72 阅读
  7. linux 文件概念

    2023-12-24 15:54:02       40 阅读
  8. 面积最大的蛋糕

    2023-12-24 15:54:02       57 阅读