博客
关于我
Patching Array
阅读量:794 次
发布时间:2023-02-26

本文共 850 字,大约阅读时间需要 2 分钟。

1 public class Solution { 2     public int minPatches(int[] nums, int n) { 3         long missed = 1; 4         int index = 0; 5         int result = 0; 6         while (missed <= n) { 7             if (index < nums.length && nums[index] <= missed) { 8                 missed += nums[index++]; 9             } else {10                 missed += missed;11                 result++;12             }13         }14         return result;15     }16 }

这个代码简单但逻辑深刻。它的工作原理如下:

1. 从[1, n]这个范围开始寻找。当你找到一个数在数组中小于当前missed时,将这个数加到missed上,并且将这个数从数组中移除。这样就能形成一个新的范围[1, missed + nums[i]]。

2. 如果没有找到符合条件的数,那么最好的选择是将missed自身加到missed上。因为在之前的步骤中,我们已经能够形成一个[1, missed)的范围。为什么不能直接加一个更大的数呢?

举个例子来理解这个逻辑。如果你有一个范围[1, missed),再加一个数x。你的目标是形成一个新的范围[1, missed + x)。在这种情况下,missed是最大的缺失数。当前的数无法覆盖到这个missed本身,因此只能选择将missed加到自身。

转载自:https://www.cnblogs.com/shuashuashua/p/5633442.html

你可能感兴趣的文章
pandas 数据框将列类型转换为字符串或分类
查看>>
pandas 数据框条件 .mean() 取决于特定列中的值
查看>>
pandas 数据框至海运分组条形图
查看>>
Pandas 数据透视表:列顺序和小计
查看>>
pandas 时序统计的高级用法!
查看>>
pandas 时间序列重新采样结束给定的一天
查看>>
pandas 根据不是常量的第三列的值将值从一列复制到另一列
查看>>
pandas 根据值从多列中的一列查找
查看>>
Pandas 根据布尔条件选择行和列
查看>>
pandas 滚动窗口 - datetime64[ns] 未实现
查看>>
pandas 版本兼容特定的蟒蛇和NumPy配置吗?
查看>>
pandas 生成excel多级表头
查看>>
Pandas 的 DataFrame 详解-ChatGPT4o作答
查看>>
pandas 读取excel数据,以字典形式输出
查看>>
Pandas 读取具有浮点值的 csv 文件会导致奇怪的舍入和小数位数
查看>>
pandas 适用,但仅适用于满足条件的行
查看>>
pandas 重新采样到每月的特定工作日
查看>>
pandas :如何删除以NaN为列名的多个列?
查看>>
pandas :我如何对堆叠的条形图进行分组?
查看>>
pandas :按移位分组和累加和(GroupBy Shift And Cumulative Sum)
查看>>