Patching Array
发布日期:2025-05-01 23:11:28 浏览次数:13 分类:精选文章

本文共 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

上一篇:Spring源码学习(二):Spring容器之prepareContext和BeanFactoryPostProcessor的介绍
下一篇:PATA1038题解(需复习)

发表评论

最新留言

表示我来过!
[***.240.166.169]2026年06月06日 11时06分49秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章