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];

java 复制代码
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;
}
相关推荐
jikiecui1 分钟前
信奥崔老师:常用编译命令g++的基本使用
算法
星海穿梭者3 分钟前
SQL SERVER 查看锁表
java·服务器·前端
shenghaide_jiahu19 分钟前
leetcode430:扁平化多级双向链表
数据结构·链表
失散1327 分钟前
软件设计师——03 数据结构(上)
数据结构·软考·软件设计师
Chance_to_win30 分钟前
数据结构之双向链表
数据结构·链表
muxin-始终如一30 分钟前
Spring框架面试问题及详细回答
java·spring·面试
Fency咖啡37 分钟前
Spring Boot 3.x 开发 Starter 快速上手体验,通过实践理解自动装配原理
java·spring boot·后端
悟能不能悟38 分钟前
什么是反应式编程
java
乌萨奇也要立志学C++42 分钟前
【洛谷】二叉树专题全解析:概念、存储、遍历与经典真题实战
数据结构·c++·算法
小谢在学习1 小时前
旋转图像
算法