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

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

问题分析:该题让找出任何数字都可以组成n,且数组时排序的,我们假设前一个数字所能组成的数字范围是1,total,那么加上一个数numsk,则范围变为1,total并上nums\[k,numsk+total],如果numsk<total,则直接可以构成1,nums\[k+total]这个范围,则表示使用nums数组是连续的,不需要添加新的数字,如果不可以,表明numsk已经断开了连接,需要添加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;
}
相关推荐
IronMurphy1 分钟前
【算法五十三】1143. 最长公共子序列
算法
被AI抢饭碗的人3 分钟前
算法:动态规划
算法
妄想出头的工业炼药师3 分钟前
激光雷达点云退化多地图会话
算法·开源
YikNjy6 分钟前
string(c++)
java·服务器·c++
不会就选b15 分钟前
数据结构之顺序表
数据结构
小江的记录本28 分钟前
【Spring AI】Spring AI中RAG误触发与系统提示词泄露问题解决方案(完整版+代码方案)
java·人工智能·spring boot·后端·python·spring·面试
z落落30 分钟前
C# Hashtable 哈希表+SortedList 有序键值对集合
数据结构·散列表
Brilliantwxx35 分钟前
【C++】 深入理解红黑树:实现与原理全解
数据结构·c++·笔记·算法·青少年编程·红黑树
勇往直前plus35 分钟前
Python 属性访问与操作全解析:内置函数、魔法方法与描述符深度指南
java·网络·python
Arenaschi41 分钟前
关于GPT的版特点
java·网络·人工智能·windows·python·gpt