mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-09-07 00:11:41 +08:00
update
This commit is contained in:
@@ -12,7 +12,7 @@
|
||||
"translatedContent": "<p>给你一个数组 <code>arr</code> ,该数组表示一个从 <code>1</code> 到 <code>n</code> 的数字排列。有一个长度为 <code>n</code> 的二进制字符串,该字符串上的所有位最初都设置为 <code>0</code> 。</p>\n\n<p>在从 <code>1</code> 到 <code>n</code> 的每个步骤 <code>i</code> 中(假设二进制字符串和 <code>arr</code> 都是从 <code>1</code> 开始索引的情况下),二进制字符串上位于位置 <code>arr[i]</code> 的位将会设为 <code>1</code> 。</p>\n\n<p>给你一个整数 <code>m</code> ,请你找出二进制字符串上存在长度为 <code>m</code> 的一组 <code>1</code> 的最后步骤。一组 <code>1</code> 是一个连续的、由 <code>1</code> 组成的子串,且左右两边不再有可以延伸的 <code>1</code> 。</p>\n\n<p>返回存在长度 <strong>恰好</strong> 为 <code>m</code> 的 <strong>一组 <code>1</code> </strong> 的最后步骤。如果不存在这样的步骤,请返回 <code>-1</code> 。</p>\n\n<p> </p>\n\n<p><strong>示例 1:</strong></p>\n\n<pre><strong>输入:</strong>arr = [3,5,1,2,4], m = 1\n<strong>输出:</strong>4\n<strong>解释:\n</strong>步骤 1:"00<strong>1</strong>00",由 1 构成的组:["1"]\n步骤 2:"0010<strong>1</strong>",由 1 构成的组:["1", "1"]\n步骤 3:"<strong>1</strong>0101",由 1 构成的组:["1", "1", "1"]\n步骤 4:"1<strong>1</strong>101",由 1 构成的组:["111", "1"]\n步骤 5:"111<strong>1</strong>1",由 1 构成的组:["11111"]\n存在长度为 1 的一组 1 的最后步骤是步骤 4 。</pre>\n\n<p><strong>示例 2:</strong></p>\n\n<pre><strong>输入:</strong>arr = [3,1,5,4,2], m = 2\n<strong>输出:</strong>-1\n<strong>解释:\n</strong>步骤 1:"00<strong>1</strong>00",由 1 构成的组:["1"]\n步骤 2:"<strong>1</strong>0100",由 1 构成的组:["1", "1"]\n步骤 3:"1010<strong>1</strong>",由 1 构成的组:["1", "1", "1"]\n步骤 4:"101<strong>1</strong>1",由 1 构成的组:["1", "111"]\n步骤 5:"1<strong>1</strong>111",由 1 构成的组:["11111"]\n不管是哪一步骤都无法形成长度为 2 的一组 1 。\n</pre>\n\n<p><strong>示例 3:</strong></p>\n\n<pre><strong>输入:</strong>arr = [1], m = 1\n<strong>输出:</strong>1\n</pre>\n\n<p><strong>示例 4:</strong></p>\n\n<pre><strong>输入:</strong>arr = [2,1], m = 2\n<strong>输出:</strong>2\n</pre>\n\n<p> </p>\n\n<p><strong>提示:</strong></p>\n\n<ul>\n\t<li><code>n == arr.length</code></li>\n\t<li><code>1 <= n <= 10^5</code></li>\n\t<li><code>1 <= arr[i] <= n</code></li>\n\t<li><code>arr</code> 中的所有整数 <strong>互不相同</strong></li>\n\t<li><code>1 <= m <= arr.length</code></li>\n</ul>\n",
|
||||
"isPaidOnly": false,
|
||||
"difficulty": "Medium",
|
||||
"likes": 52,
|
||||
"likes": 54,
|
||||
"dislikes": 0,
|
||||
"isLiked": null,
|
||||
"similarQuestions": "[]",
|
||||
@@ -149,7 +149,7 @@
|
||||
"__typename": "CodeSnippetNode"
|
||||
}
|
||||
],
|
||||
"stats": "{\"totalAccepted\": \"4.6K\", \"totalSubmission\": \"14.6K\", \"totalAcceptedRaw\": 4582, \"totalSubmissionRaw\": 14551, \"acRate\": \"31.5%\"}",
|
||||
"stats": "{\"totalAccepted\": \"4.7K\", \"totalSubmission\": \"14.9K\", \"totalAcceptedRaw\": 4748, \"totalSubmissionRaw\": 14904, \"acRate\": \"31.9%\"}",
|
||||
"hints": [
|
||||
"Since the problem asks for the latest step, can you start the searching from the end of arr?",
|
||||
"Use a map to store the current “1” groups.",
|
||||
|
Reference in New Issue
Block a user