@@ -81459,7 +81459,7 @@ <h2 id="solutions">Solutions</h2>
81459
81459
<h3 id="solution-1-counting">Solution 1: Counting</h3>
81460
81460
<p>According to the problem, we need to divide the array into two parts, and the elements in each part are all distinct. Therefore, we can count the occurrence of each element in the array. If an element appears three or more times, it cannot satisfy the problem's requirements. Otherwise, we can divide the array into two parts.</p>
81461
81461
<p>The time complexity is $O(n)$, and the space complexity is $O(n)$. Where $n$ is the length of the array.</p>
81462
- <div class="tabbed-set tabbed-alternate" data-tabs="1:5 "><input checked="checked" id="__tabbed_1_1" name="__tabbed_1" type="radio" /><input id="__tabbed_1_2" name="__tabbed_1" type="radio" /><input id="__tabbed_1_3" name="__tabbed_1" type="radio" /><input id="__tabbed_1_4" name="__tabbed_1" type="radio" /><input id="__tabbed_1_5" name="__tabbed_1" type="radio" /><div class="tabbed-labels"><label for="__tabbed_1_1">Python3</label><label for="__tabbed_1_2">Java</label><label for="__tabbed_1_3">C++</label><label for="__tabbed_1_4">Go</label><label for="__tabbed_1_5">TypeScript</label></div>
81462
+ <div class="tabbed-set tabbed-alternate" data-tabs="1:7 "><input checked="checked" id="__tabbed_1_1" name="__tabbed_1" type="radio" /><input id="__tabbed_1_2" name="__tabbed_1" type="radio" /><input id="__tabbed_1_3" name="__tabbed_1" type="radio" /><input id="__tabbed_1_4" name="__tabbed_1" type="radio" /><input id="__tabbed_1_5" name="__tabbed_1" type="radio" /><input id="__tabbed_1_6" name="__tabbed_1" type="radio" /><input id="__tabbed_1_7" name="__tabbed_1" type="radio" />< div class="tabbed-labels"><label for="__tabbed_1_1">Python3</label><label for="__tabbed_1_2">Java</label><label for="__tabbed_1_3">C++</label><label for="__tabbed_1_4">Go</label><label for="__tabbed_1_5">TypeScript</label><label for="__tabbed_1_6">Rust</label><label for="__tabbed_1_7">C# </label></div>
81463
81463
<div class="tabbed-content">
81464
81464
<div class="tabbed-block">
81465
81465
<div class="highlight"><table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><span></span><span class="normal">1</span>
@@ -81561,6 +81561,54 @@ <h3 id="solution-1-counting">Solution 1: Counting</h3>
81561
81561
<span class="p">}</span>
81562
81562
</code></pre></div></td></tr></table></div>
81563
81563
</div>
81564
+ <div class="tabbed-block">
81565
+ <div class="highlight"><table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><span></span><span class="normal"> 1</span>
81566
+ <span class="normal"> 2</span>
81567
+ <span class="normal"> 3</span>
81568
+ <span class="normal"> 4</span>
81569
+ <span class="normal"> 5</span>
81570
+ <span class="normal"> 6</span>
81571
+ <span class="normal"> 7</span>
81572
+ <span class="normal"> 8</span>
81573
+ <span class="normal"> 9</span>
81574
+ <span class="normal">10</span>
81575
+ <span class="normal">11</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="k">use</span><span class="w"> </span><span class="n">std</span><span class="p">::</span><span class="n">collections</span><span class="p">::</span><span class="n">HashMap</span><span class="p">;</span>
81576
+
81577
+ <span class="k">impl</span><span class="w"> </span><span class="n">Solution</span><span class="w"> </span><span class="p">{</span>
81578
+ <span class="w"> </span><span class="k">pub</span><span class="w"> </span><span class="k">fn</span><span class="w"> </span><span class="nf">is_possible_to_split</span><span class="p">(</span><span class="n">nums</span><span class="p">:</span><span class="w"> </span><span class="nb">Vec</span><span class="o"><</span><span class="kt">i32</span><span class="o">></span><span class="p">)</span><span class="w"> </span><span class="p">-></span><span class="w"> </span><span class="kt">bool</span><span class="w"> </span><span class="p">{</span>
81579
+ <span class="w"> </span><span class="kd">let</span><span class="w"> </span><span class="k">mut</span><span class="w"> </span><span class="n">cnt</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">HashMap</span><span class="p">::</span><span class="n">new</span><span class="p">();</span>
81580
+ <span class="w"> </span><span class="k">for</span><span class="w"> </span><span class="o">&</span><span class="n">x</span><span class="w"> </span><span class="k">in</span><span class="w"> </span><span class="o">&</span><span class="n">nums</span><span class="w"> </span><span class="p">{</span>
81581
+ <span class="w"> </span><span class="o">*</span><span class="n">cnt</span><span class="p">.</span><span class="n">entry</span><span class="p">(</span><span class="n">x</span><span class="p">).</span><span class="n">or_insert</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span><span class="w"> </span><span class="o">+=</span><span class="w"> </span><span class="mi">1</span><span class="p">;</span>
81582
+ <span class="w"> </span><span class="p">}</span>
81583
+ <span class="w"> </span><span class="o">*</span><span class="n">cnt</span><span class="p">.</span><span class="n">values</span><span class="p">().</span><span class="n">max</span><span class="p">().</span><span class="n">unwrap_or</span><span class="p">(</span><span class="o">&</span><span class="mi">0</span><span class="p">)</span><span class="w"> </span><span class="o"><</span><span class="w"> </span><span class="mi">3</span>
81584
+ <span class="w"> </span><span class="p">}</span>
81585
+ <span class="p">}</span>
81586
+ </code></pre></div></td></tr></table></div>
81587
+ </div>
81588
+ <div class="tabbed-block">
81589
+ <div class="highlight"><table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><span></span><span class="normal"> 1</span>
81590
+ <span class="normal"> 2</span>
81591
+ <span class="normal"> 3</span>
81592
+ <span class="normal"> 4</span>
81593
+ <span class="normal"> 5</span>
81594
+ <span class="normal"> 6</span>
81595
+ <span class="normal"> 7</span>
81596
+ <span class="normal"> 8</span>
81597
+ <span class="normal"> 9</span>
81598
+ <span class="normal">10</span>
81599
+ <span class="normal">11</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="k">public</span><span class="w"> </span><span class="k">class</span><span class="w"> </span><span class="nc">Solution</span><span class="w"> </span><span class="p">{</span>
81600
+ <span class="w"> </span><span class="k">public</span><span class="w"> </span><span class="kt">bool</span><span class="w"> </span><span class="nf">IsPossibleToSplit</span><span class="p">(</span><span class="kt">int</span><span class="p">[]</span><span class="w"> </span><span class="n">nums</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
81601
+ <span class="w"> </span><span class="kt">int</span><span class="p">[]</span><span class="w"> </span><span class="n">cnt</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="k">new</span><span class="w"> </span><span class="kt">int</span><span class="p">[</span><span class="m">101</span><span class="p">];</span>
81602
+ <span class="w"> </span><span class="k">foreach</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="n">x</span><span class="w"> </span><span class="k">in</span><span class="w"> </span><span class="n">nums</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
81603
+ <span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="p">(</span><span class="o">++</span><span class="n">cnt</span><span class="p">[</span><span class="n">x</span><span class="p">]</span><span class="w"> </span><span class="o">>=</span><span class="w"> </span><span class="m">3</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
81604
+ <span class="w"> </span><span class="k">return</span><span class="w"> </span><span class="k">false</span><span class="p">;</span>
81605
+ <span class="w"> </span><span class="p">}</span>
81606
+ <span class="w"> </span><span class="p">}</span>
81607
+ <span class="w"> </span><span class="k">return</span><span class="w"> </span><span class="k">true</span><span class="p">;</span>
81608
+ <span class="w"> </span><span class="p">}</span>
81609
+ <span class="p">}</span>
81610
+ </code></pre></div></td></tr></table></div>
81611
+ </div>
81564
81612
</div>
81565
81613
</div>
81566
81614
<!-- solution:end -->
0 commit comments