927:三等分

This commit is contained in:
轩辕龙儿 2022-03-14 17:05:34 +08:00
parent a8e982ffed
commit 8035ce9d82
2 changed files with 151 additions and 0 deletions

View File

@ -0,0 +1,104 @@
//给定一个由 0 1 组成的数组 arr 将数组分成 3 个非空的部分 使得所有这些部分表示相同的二进制值
//
// 如果可以做到请返回任何 [i, j]其中 i+1 < j这样一来
//
//
// arr[0], arr[1], ..., arr[i] 为第一部分
// arr[i + 1], arr[i + 2], ..., arr[j - 1] 为第二部分
// arr[j], arr[j + 1], ..., arr[arr.length - 1] 为第三部分
// 这三个部分所表示的二进制值相等
//
//
// 如果无法做到就返回 [-1, -1]
//
// 注意在考虑每个部分所表示的二进制时应当将其看作一个整体例如[1,1,0] 表示十进制中的 6而不会是 3此外前导零也是被允许的所以 [0,
//1,1] [1,1] 表示相同的值
//
//
//
// 示例 1
//
//
//输入arr = [1,0,1,0,1]
//输出[0,3]
//
//
// 示例 2
//
//
//输入arr = [1,1,0,1,1]
//输出[-1,-1]
//
// 示例 3:
//
//
//输入arr = [1,1,0,0,1]
//输出[0,2]
//
//
//
//
// 提示
//
//
//
// 3 <= arr.length <= 3 * 10
// arr[i] 0 1
//
// Related Topics 数组 数学 👍 61 👎 0
package leetcode.editor.cn;
import java.util.ArrayList;
import java.util.List;
//927:三等分
public class ThreeEqualParts {
public static void main(String[] args) {
Solution solution = new ThreeEqualParts().new Solution();
// TO TEST
solution.threeEqualParts(new int[]{1, 0, 1, 0, 1});
}
//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
public int[] threeEqualParts(int[] arr) {
List<Integer> count1 = new ArrayList<>();
StringBuilder str = new StringBuilder();
for (int i = 0; i < arr.length; i++) {
str.append(arr[i]);
if (arr[i] == 1) {
count1.add(i);
}
}
if (count1.size() == 0) {
return new int[]{0, 2};
}
if (count1.size() % 3 > 0) {
return new int[]{-1, -1};
}
int ori = count1.size() - count1.size() / 3;
int right = count1.get(ori);
String comStr = str.substring(right);
str = new StringBuilder(str.substring(0, right));
int left = str.lastIndexOf(comStr);
if (left < 0 || left + comStr.length() - 1 < count1.get(ori - 1)) {
return new int[]{-1, -1};
}
right = left + comStr.length();
str = new StringBuilder(str.substring(0, left));
int index = str.lastIndexOf(comStr);
if (index < 0) {
return new int[]{-1, -1};
}
left = index + comStr.length() - 1;
return new int[]{left, right};
}
}
//leetcode submit region end(Prohibit modification and deletion)
}

View File

@ -0,0 +1,47 @@
<p>给定一个由 <code>0</code><code>1</code> 组成的数组<meta charset="UTF-8" />&nbsp;<code>arr</code>&nbsp;,将数组分成 &nbsp;<strong>3&nbsp;个非空的部分</strong> ,使得所有这些部分表示相同的二进制值。</p>
<p>如果可以做到,请返回<strong>任何</strong>&nbsp;<code>[i, j]</code>,其中 <code>i+1 &lt; j</code>,这样一来:</p>
<ul>
<li><code>arr[0], arr[1], ..., arr[i]</code>&nbsp;为第一部分;</li>
<li><code>arr[i + 1], arr[i + 2], ..., arr[j - 1]</code>&nbsp;为第二部分;</li>
<li><code>arr[j], arr[j + 1], ..., arr[arr.length - 1]</code>&nbsp;为第三部分。</li>
<li>这三个部分所表示的二进制值相等。</li>
</ul>
<p>如果无法做到,就返回&nbsp;<code>[-1, -1]</code></p>
<p>注意,在考虑每个部分所表示的二进制时,应当将其看作一个整体。例如,<code>[1,1,0]</code>&nbsp;表示十进制中的&nbsp;<code>6</code>,而不会是&nbsp;<code>3</code>。此外,前导零也是<strong>被允许</strong>的,所以&nbsp;<code>[0,1,1]</code>&nbsp;<code>[1,1]</code>&nbsp;表示相同的值。</p>
<p>&nbsp;</p>
<p><strong>示例 1</strong></p>
<pre>
<strong>输入:</strong>arr = [1,0,1,0,1]
<strong>输出:</strong>[0,3]
</pre>
<p><strong>示例 2</strong></p>
<pre>
<strong>输入:</strong>arr = [1,1,0,1,1]
<strong>输出:</strong>[-1,-1]</pre>
<p><strong>示例 3:</strong></p>
<pre>
<strong>输入:</strong>arr = [1,1,0,0,1]
<strong>输出:</strong>[0,2]
</pre>
<p>&nbsp;</p>
<p><strong>提示:</strong></p>
<meta charset="UTF-8" />
<ul>
<li><code>3 &lt;= arr.length &lt;= 3 * 10<sup>4</sup></code></li>
<li><code>arr[i]</code>&nbsp;&nbsp;<code>0</code>&nbsp;&nbsp;<code>1</code></li>
</ul>
<div><div>Related Topics</div><div><li>数组</li><li>数学</li></div></div><br><div><li>👍 61</li><li>👎 0</li></div>