1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-10-24 06:18:57 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
Files
leetcode-problemset/leetcode-cn/problem (Chinese)/将所有元素变为 0 的最少操作次数 [minimum-operations-to-convert-all-elements-to-zero].html
2025-05-15 01:05:54 +08:00

68 lines
2.9 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<p>给你一个大小为 <code>n</code><strong>非负</strong>&nbsp;整数数组 <code>nums</code>&nbsp;。你的任务是对该数组执行若干次(可能为 0 次)操作,使得&nbsp;<strong>所有&nbsp;</strong>元素都变为 0。</p>
<p>在一次操作中,你可以选择一个子数组 <code>[i, j]</code>(其中 <code>0 &lt;= i &lt;= j &lt; n</code>),将该子数组中所有&nbsp;<strong>最小的非负整数&nbsp;</strong>的设为 0。</p>
<p>返回使整个数组变为 0 所需的<strong>最少</strong>操作次数。</p>
一个&nbsp;<strong>子数组&nbsp;</strong>是数组中的一段连续元素。
<p>&nbsp;</p>
<p><strong class="example">示例 1</strong></p>
<div class="example-block">
<p><strong>输入:</strong> <span class="example-io">nums = [0,2]</span></p>
<p><strong>输出:</strong> <span class="example-io">1</span></p>
<p><strong>解释:</strong></p>
<ul>
<li>选择子数组 <code>[1,1]</code>(即 <code>[2]</code>),其中最小的非负整数是 2。将所有 2 设为 0结果为 <code>[0,0]</code></li>
<li>因此,所需的最少操作次数为 1。</li>
</ul>
</div>
<p><strong class="example">示例 2</strong></p>
<div class="example-block">
<p><strong>输入:</strong> <span class="example-io">nums = [3,1,2,1]</span></p>
<p><strong>输出:</strong> <span class="example-io">3</span></p>
<p><strong>解释:</strong></p>
<ul>
<li>选择子数组 <code>[1,3]</code>(即 <code>[1,2,1]</code>),最小非负整数是 1。将所有 1 设为 0结果为 <code>[3,0,2,0]</code></li>
<li>选择子数组 <code>[2,2]</code>(即 <code>[2]</code>),将 2 设为 0结果为 <code>[3,0,0,0]</code></li>
<li>选择子数组 <code>[0,0]</code>(即 <code>[3]</code>),将 3 设为 0结果为 <code>[0,0,0,0]</code></li>
<li>因此,最少操作次数为 3。</li>
</ul>
</div>
<p><strong class="example">示例 3</strong></p>
<div class="example-block">
<p><strong>输入:</strong> <span class="example-io">nums = [1,2,1,2,1,2]</span></p>
<p><strong>输出:</strong> <span class="example-io">4</span></p>
<p><strong>解释:</strong></p>
<ul>
<li>选择子数组 <code>[0,5]</code>(即 <code>[1,2,1,2,1,2]</code>),最小非负整数是 1。将所有 1 设为 0结果为 <code>[0,2,0,2,0,2]</code></li>
<li>选择子数组 <code>[1,1]</code>(即 <code>[2]</code>),将 2 设为 0结果为 <code>[0,0,0,2,0,2]</code></li>
<li>选择子数组 <code>[3,3]</code>(即 <code>[2]</code>),将 2 设为 0结果为 <code>[0,0,0,0,0,2]</code></li>
<li>选择子数组 <code>[5,5]</code>(即 <code>[2]</code>),将 2 设为 0结果为 <code>[0,0,0,0,0,0]</code></li>
<li>因此,最少操作次数为 4。</li>
</ul>
</div>
<p>&nbsp;</p>
<p><strong>提示:</strong></p>
<ul>
<li><code>1 &lt;= n == nums.length &lt;= 10<sup>5</sup></code></li>
<li><code>0 &lt;= nums[i] &lt;= 10<sup>5</sup></code></li>
</ul>