1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-10-19 12:06:48 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
This commit is contained in:
2022-07-17 17:35:36 +08:00
parent ea34fbb843
commit 86906ca247
27 changed files with 13775 additions and 11552 deletions

View File

@@ -0,0 +1,35 @@
<p>给你两个正整数数组&nbsp;<code>nums</code>&nbsp;<code>numsDivide</code>&nbsp;。你可以从&nbsp;<code>nums</code>&nbsp;中删除任意数目的元素。</p>
<p>请你返回使 <code>nums</code>&nbsp;<strong>最小</strong>&nbsp;元素可以整除 <code>numsDivide</code>&nbsp;中所有元素的 <strong>最少</strong>&nbsp;删除次数。如果无法得到这样的元素,返回 <code>-1</code>&nbsp;</p>
<p>如果&nbsp;<code>y % x == 0</code>&nbsp;,那么我们说整数&nbsp;<code>x</code>&nbsp;整除&nbsp;<code>y</code>&nbsp;</p>
<p>&nbsp;</p>
<p><strong>示例 1</strong></p>
<pre><b>输入:</b>nums = [2,3,2,4,3], numsDivide = [9,6,9,3,15]
<b>输出:</b>2
<b>解释:</b>
[2,3,2,4,3] 中最小元素是 2 ,它无法整除 numsDivide 中所有元素。
我们从 nums 中删除 2 个大小为 2 的元素,得到 nums = [3,4,3] 。
[3,4,3] 中最小元素为 3 ,它可以整除 numsDivide 中所有元素。
可以证明 2 是最少删除次数。
</pre>
<p><strong>示例 2</strong></p>
<pre><b>输入:</b>nums = [4,3,6], numsDivide = [8,2,6,10]
<b>输出:</b>-1
<b>解释:</b>
我们想 nums 中的最小元素可以整除 numsDivide 中的所有元素。
没有任何办法可以达到这一目的。</pre>
<p>&nbsp;</p>
<p><strong>提示:</strong></p>
<ul>
<li><code>1 &lt;= nums.length, numsDivide.length &lt;= 10<sup>5</sup></code></li>
<li><code>1 &lt;= nums[i], numsDivide[i] &lt;= 10<sup>9</sup></code></li>
</ul>

View File

@@ -0,0 +1,32 @@
<p>给你一个下标从 <strong>0</strong> 开始的数组 <code>nums</code> ,数组中的元素都是 <strong></strong> 整数。请你选出两个下标 <code>i</code><code>j</code><code>i != j</code>),且 <code>nums[i]</code> 的数位和 与&nbsp; <code>nums[j]</code> 的数位和相等。</p>
<p>请你找出所有满足条件的下标 <code>i</code><code>j</code> ,找出并返回<em> </em><code>nums[i] + nums[j]</code><em> </em>可以得到的 <strong>最大值</strong> <em></em></p>
<p>&nbsp;</p>
<p><strong>示例 1</strong></p>
<pre>
<strong>输入:</strong>nums = [18,43,36,13,7]
<strong>输出:</strong>54
<strong>解释:</strong>满足条件的数对 (i, j) 为:
- (0, 2) ,两个数字的数位和都是 9 ,相加得到 18 + 36 = 54 。
- (1, 4) ,两个数字的数位和都是 7 ,相加得到 43 + 7 = 50 。
所以可以获得的最大和是 54 。</pre>
<p><strong>示例 2</strong></p>
<pre>
<strong>输入:</strong>nums = [10,12,19,14]
<strong>输出:</strong>-1
<strong>解释:</strong>不存在满足条件的数对,返回 -1 。
</pre>
<p>&nbsp;</p>
<p><strong>提示:</strong></p>
<ul>
<li><code>1 &lt;= nums.length &lt;= 10<sup>5</sup></code></li>
<li><code>1 &lt;= nums[i] &lt;= 10<sup>9</sup></code></li>
</ul>

View File

@@ -0,0 +1,45 @@
<p>给你一个下标从 <strong>0</strong> 开始的整数数组 <code>nums</code> 。在一步操作中,你可以执行以下步骤:</p>
<ul>
<li><code>nums</code> 选出 <strong>两个</strong> <strong>相等的</strong> 整数</li>
<li><code>nums</code> 中移除这两个整数,形成一个 <strong>数对</strong></li>
</ul>
<p>请你在 <code>nums</code> 上多次执行此操作直到无法继续执行。</p>
<p>返回一个下标从 <strong>0</strong> 开始、长度为 <code>2</code> 的整数数组 <code>answer</code> 作为答案,其中<em> </em><code>answer[0]</code><em> </em>是形成的数对数目,<code>answer[1]</code> 是对 <code>nums</code> 尽可能执行上述操作后剩下的整数数目。</p>
<p>&nbsp;</p>
<p><strong>示例 1</strong></p>
<pre><strong>输入:</strong>nums = [1,3,2,1,3,2,2]
<strong>输出:</strong>[3,1]
<strong>解释:</strong>
nums[0] 和 nums[3] 形成一个数对,并从 nums 中移除nums = [3,2,3,2,2] 。
nums[0] 和 nums[2] 形成一个数对,并从 nums 中移除nums = [2,2,2] 。
nums[0] 和 nums[1] 形成一个数对,并从 nums 中移除nums = [2] 。
无法形成更多数对。总共形成 3 个数对nums 中剩下 1 个数字。</pre>
<p><strong>示例 2</strong></p>
<pre><strong>输入:</strong>nums = [1,1]
<strong>输出:</strong>[1,0]
<strong>解释:</strong>nums[0] 和 nums[1] 形成一个数对,并从 nums 中移除nums = [] 。
无法形成更多数对。总共形成 1 个数对nums 中剩下 0 个数字。</pre>
<p><strong>示例 3</strong></p>
<pre><strong>输入:</strong>nums = [0]
<strong>输出:</strong>[0,1]
<strong>解释:</strong>无法形成数对nums 中剩下 1 个数字。
</pre>
<p>&nbsp;</p>
<p><strong>提示:</strong></p>
<ul>
<li><code>1 &lt;= nums.length &lt;= 100</code></li>
<li><code>0 &lt;= nums[i] &lt;= 100</code></li>
</ul>

View File

@@ -0,0 +1,59 @@
<p>给你一个下标从 <strong>0</strong>&nbsp;开始的字符串数组&nbsp;<code>nums</code>&nbsp;,其中每个字符串 <strong>长度相等</strong>&nbsp;且只包含数字。</p>
<p>再给你一个下标从 <strong>0</strong>&nbsp;开始的二维整数数组&nbsp;<code>queries</code>&nbsp;,其中&nbsp;<code>queries[i] = [k<sub>i</sub>, trim<sub>i</sub>]</code>&nbsp;。对于每个&nbsp;<code>queries[i]</code>&nbsp;,你需要:</p>
<ul>
<li>&nbsp;<code>nums</code>&nbsp;中每个数字 <strong>裁剪</strong>&nbsp;到剩下 <strong>最右边</strong>&nbsp;<code>trim<sub>i</sub></code>&nbsp;个数位。</li>
<li>在裁剪过后的数字中,找到 <code>nums</code>&nbsp;中第&nbsp;<code>k<sub>i</sub></code>&nbsp;小数字对应的 <strong>下标</strong>&nbsp;。如果两个裁剪后数字一样大,那么下标 <strong>更小</strong>&nbsp;的数字视为更小的数字。</li>
<li><code>nums</code>&nbsp;中每个数字恢复到原本字符串。</li>
</ul>
<p>请你返回一个长度与 <code><span style="">queries</span></code>&nbsp;相等的数组<em>&nbsp;</em><code>answer</code>,其中<em>&nbsp;</em><code>answer[i]</code>是第<em>&nbsp;</em><code>i</code><em>&nbsp;</em>次查询的结果。</p>
<p><strong>提示:</strong></p>
<ul>
<li>裁剪到剩下 <code>x</code>&nbsp;个数位的意思是不断删除最左边的数位,直到剩下 <code>x</code>&nbsp;个数位。</li>
<li><code>nums</code>&nbsp;中的字符串可能会有前导 0 。</li>
</ul>
<p>&nbsp;</p>
<p><strong>示例 1</strong></p>
<pre>
<b>输入:</b>nums = ["102","473","251","814"], queries = [[1,1],[2,3],[4,2],[1,2]]
<b>输出:</b>[2,2,1,0]
<strong>解释:</strong>
1. 裁剪到只剩 1 个数位后nums = ["2","3","1","4"] 。最小的数字是 1 ,下标为 2 。
2. 裁剪到剩 3 个数位后nums 没有变化。第 2 小的数字是 251 ,下标为 2 。
3. 裁剪到剩 2 个数位后nums = ["02","73","51","14"] 。第 4 小的数字是 73 ,下标为 1 。
4. 裁剪到剩 2 个数位后,最小数字是 2 ,下标为 0 。
注意,裁剪后数字 "02" 值为 2 。
</pre>
<p><strong>示例 2</strong></p>
<pre>
<b>输入:</b>nums = ["24","37","96","04"], queries = [[2,1],[2,2]]
<b>输出:</b>[3,0]
<strong>解释:</strong>
1. 裁剪到剩 1 个数位nums = ["4","7","6","4"] 。第 2 小的数字是 4 ,下标为 3 。
有两个 4 ,下标为 0 的 4 视为小于下标为 3 的 4 。
2. 裁剪到剩 2 个数位nums 不变。第二小的数字是 24 ,下标为 0 。
</pre>
<p>&nbsp;</p>
<p><b>提示:</b></p>
<ul>
<li><code>1 &lt;= nums.length &lt;= 100</code></li>
<li><code>1 &lt;= nums[i].length &lt;= 100</code></li>
<li><code>nums[i]</code> 只包含数字。</li>
<li>所有&nbsp;<code>nums[i].length</code>&nbsp;的长度 <b>相同</b>&nbsp;</li>
<li><code>1 &lt;= queries.length &lt;= 100</code></li>
<li><code>queries[i].length == 2</code></li>
<li><code>1 &lt;= k<sub>i</sub> &lt;= nums.length</code></li>
<li><code>1 &lt;= trim<sub>i</sub> &lt;= nums[0].length</code></li>
</ul>