1. 解题思路
这一题的话基础的思路就是二分法查找最小的可以将所有的数字都mark上的最小位置。
因此,这里的问题就会变成如何快速地判断对于一个给定的位置,能否在这个操作序列下将所有的数字全部mark上。
而考虑的可能的操作,显然有:
- 要将一个数mark上,必须在某次操作时其给出的mark indice正好为这个位置,且之前已经将其减为0了。
因此,我们就要确保:
- 在对应的操作序列下所有的位置至少都出现过一次;
- 在最后一次出现某一位置的操作前,我们可以将对应位置上的值变为0;
因此,我们只需要对每一个长度的操作序列,判断其各个位置的操作是否齐全以及其最后一次操作的位置,然后分配一下decrease的顺序是否可以满足即可。
2. 代码实现
给出python代码实现如下:
class Solution:
def earliestSecondToMarkIndices(self, nums: List[int], changeIndices: List[int]) -

本文介绍了LeetCode问题3048的解题思路,利用二分查找确定最小操作次数,确保每个位置都被标记且在最后一次操作前变为0。给出了Python代码实现,展示了如何检查操作序列的可行性并优化查找过程。
最低0.47元/天 解锁文章
1万+

被折叠的 条评论
为什么被折叠?



