Skip to content

Commit 4a0a012

Browse files
committed
deploy: 398146b
1 parent 0902845 commit 4a0a012

File tree

11 files changed

+8216
-7809
lines changed

11 files changed

+8216
-7809
lines changed

en/lc/146/index.html

Lines changed: 438 additions & 222 deletions
Large diffs are not rendered by default.

en/lc/23/index.html

Lines changed: 4 additions & 20 deletions
Original file line numberDiff line numberDiff line change
@@ -81861,11 +81861,7 @@ <h3 id="solution-1-priority-queue-min-heap">Solution 1: Priority Queue (Min Heap
8186181861
<span class="normal">24</span>
8186281862
<span class="normal">25</span>
8186381863
<span class="normal">26</span>
81864-
<span class="normal">27</span>
81865-
<span class="normal">28</span>
81866-
<span class="normal">29</span>
81867-
<span class="normal">30</span>
81868-
<span class="normal">31</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="cm">/**</span>
81864+
<span class="normal">27</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="cm">/**</span>
8186981865
<span class="cm"> * Definition for singly-linked list.</span>
8187081866
<span class="cm"> * class ListNode {</span>
8187181867
<span class="cm"> * val: number</span>
@@ -81879,11 +81875,7 @@ <h3 id="solution-1-priority-queue-min-heap">Solution 1: Priority Queue (Min Heap
8187981875

8188081876
<span class="kd">function</span><span class="w"> </span><span class="nx">mergeKLists</span><span class="p">(</span><span class="nx">lists</span><span class="o">:</span><span class="w"> </span><span class="kt">Array</span><span class="o">&lt;</span><span class="nx">ListNode</span><span class="w"> </span><span class="o">|</span><span class="w"> </span><span class="kc">null</span><span class="o">&gt;</span><span class="p">)</span><span class="o">:</span><span class="w"> </span><span class="nx">ListNode</span><span class="w"> </span><span class="o">|</span><span class="w"> </span><span class="kc">null</span><span class="w"> </span><span class="p">{</span>
8188181877
<span class="w"> </span><span class="kd">const</span><span class="w"> </span><span class="nx">pq</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="ow">new</span><span class="w"> </span><span class="nx">MinPriorityQueue</span><span class="p">({</span><span class="w"> </span><span class="nx">priority</span><span class="o">:</span><span class="w"> </span><span class="p">(</span><span class="nx">node</span><span class="o">:</span><span class="w"> </span><span class="kt">ListNode</span><span class="p">)</span><span class="w"> </span><span class="p">=&gt;</span><span class="w"> </span><span class="nx">node</span><span class="p">.</span><span class="nx">val</span><span class="w"> </span><span class="p">});</span>
81882-
<span class="w"> </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="kd">const</span><span class="w"> </span><span class="nx">head</span><span class="w"> </span><span class="k">of</span><span class="w"> </span><span class="nx">lists</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
81883-
<span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="p">(</span><span class="nx">head</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
81884-
<span class="w"> </span><span class="nx">pq</span><span class="p">.</span><span class="nx">enqueue</span><span class="p">(</span><span class="nx">head</span><span class="p">);</span>
81885-
<span class="w"> </span><span class="p">}</span>
81886-
<span class="w"> </span><span class="p">}</span>
81878+
<span class="w"> </span><span class="nx">lists</span><span class="p">.</span><span class="nx">filter</span><span class="p">(</span><span class="nx">head</span><span class="w"> </span><span class="p">=&gt;</span><span class="w"> </span><span class="nx">head</span><span class="p">).</span><span class="nx">forEach</span><span class="p">(</span><span class="nx">head</span><span class="w"> </span><span class="p">=&gt;</span><span class="w"> </span><span class="nx">pq</span><span class="p">.</span><span class="nx">enqueue</span><span class="p">(</span><span class="nx">head</span><span class="p">));</span>
8188781879
<span class="w"> </span><span class="kd">const</span><span class="w"> </span><span class="nx">dummy</span><span class="o">:</span><span class="w"> </span><span class="kt">ListNode</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="ow">new</span><span class="w"> </span><span class="nx">ListNode</span><span class="p">();</span>
8188881880
<span class="w"> </span><span class="kd">let</span><span class="w"> </span><span class="nx">cur</span><span class="o">:</span><span class="w"> </span><span class="kt">ListNode</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="nx">dummy</span><span class="p">;</span>
8188981881
<span class="w"> </span><span class="k">while</span><span class="w"> </span><span class="p">(</span><span class="o">!</span><span class="nx">pq</span><span class="p">.</span><span class="nx">isEmpty</span><span class="p">())</span><span class="w"> </span><span class="p">{</span>
@@ -82018,11 +82010,7 @@ <h3 id="solution-1-priority-queue-min-heap">Solution 1: Priority Queue (Min Heap
8201882010
<span class="normal">23</span>
8201982011
<span class="normal">24</span>
8202082012
<span class="normal">25</span>
82021-
<span class="normal">26</span>
82022-
<span class="normal">27</span>
82023-
<span class="normal">28</span>
82024-
<span class="normal">29</span>
82025-
<span class="normal">30</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="cm">/**</span>
82013+
<span class="normal">26</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="cm">/**</span>
8202682014
<span class="cm"> * Definition for singly-linked list.</span>
8202782015
<span class="cm"> * function ListNode(val, next) {</span>
8202882016
<span class="cm"> * this.val = (val===undefined ? 0 : val)</span>
@@ -82035,11 +82023,7 @@ <h3 id="solution-1-priority-queue-min-heap">Solution 1: Priority Queue (Min Heap
8203582023
<span class="cm"> */</span>
8203682024
<span class="kd">var</span><span class="w"> </span><span class="nx">mergeKLists</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="kd">function</span><span class="w"> </span><span class="p">(</span><span class="nx">lists</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
8203782025
<span class="w"> </span><span class="kd">const</span><span class="w"> </span><span class="nx">pq</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="ow">new</span><span class="w"> </span><span class="nx">MinPriorityQueue</span><span class="p">({</span><span class="w"> </span><span class="nx">priority</span><span class="o">:</span><span class="w"> </span><span class="nx">node</span><span class="w"> </span><span class="p">=&gt;</span><span class="w"> </span><span class="nx">node</span><span class="p">.</span><span class="nx">val</span><span class="w"> </span><span class="p">});</span>
82038-
<span class="w"> </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="kd">const</span><span class="w"> </span><span class="nx">head</span><span class="w"> </span><span class="k">of</span><span class="w"> </span><span class="nx">lists</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
82039-
<span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="p">(</span><span class="nx">head</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
82040-
<span class="w"> </span><span class="nx">pq</span><span class="p">.</span><span class="nx">enqueue</span><span class="p">(</span><span class="nx">head</span><span class="p">);</span>
82041-
<span class="w"> </span><span class="p">}</span>
82042-
<span class="w"> </span><span class="p">}</span>
82026+
<span class="w"> </span><span class="nx">lists</span><span class="p">.</span><span class="nx">filter</span><span class="p">(</span><span class="nx">head</span><span class="w"> </span><span class="p">=&gt;</span><span class="w"> </span><span class="nx">head</span><span class="p">).</span><span class="nx">forEach</span><span class="p">(</span><span class="nx">head</span><span class="w"> </span><span class="p">=&gt;</span><span class="w"> </span><span class="nx">pq</span><span class="p">.</span><span class="nx">enqueue</span><span class="p">(</span><span class="nx">head</span><span class="p">));</span>
8204382027
<span class="w"> </span><span class="kd">const</span><span class="w"> </span><span class="nx">dummy</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="ow">new</span><span class="w"> </span><span class="nx">ListNode</span><span class="p">();</span>
8204482028
<span class="w"> </span><span class="kd">let</span><span class="w"> </span><span class="nx">cur</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="nx">dummy</span><span class="p">;</span>
8204582029
<span class="w"> </span><span class="k">while</span><span class="w"> </span><span class="p">(</span><span class="o">!</span><span class="nx">pq</span><span class="p">.</span><span class="nx">isEmpty</span><span class="p">())</span><span class="w"> </span><span class="p">{</span>

en/lc/649/index.html

Lines changed: 17 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -20967,9 +20967,9 @@
2096720967
<ul class="md-nav__list">
2096820968

2096920969
<li class="md-nav__item">
20970-
<a href="#solution-1" class="md-nav__link">
20970+
<a href="#solution-1-queue-simulation" class="md-nav__link">
2097120971
<span class="md-ellipsis">
20972-
Solution 1
20972+
Solution 1: Queue + Simulation
2097320973
</span>
2097420974
</a>
2097520975

@@ -81551,9 +81551,9 @@ <h2 id="description">Description</h2>
8155181551
<pre>
8155281552
<strong>Input:</strong> senate = &quot;RD&quot;
8155381553
<strong>Output:</strong> &quot;Radiant&quot;
81554-
<strong>Explanation:</strong>
81555-
The first senator comes from Radiant and he can just ban the next senator&#39;s right in round 1.
81556-
And the second senator can&#39;t exercise any rights anymore since his right has been banned.
81554+
<strong>Explanation:</strong>
81555+
The first senator comes from Radiant and he can just ban the next senator&#39;s right in round 1.
81556+
And the second senator can&#39;t exercise any rights anymore since his right has been banned.
8155781557
And in round 2, the first senator can just announce the victory since he is the only guy in the senate who can vote.
8155881558
</pre>
8155981559

@@ -81562,10 +81562,10 @@ <h2 id="description">Description</h2>
8156281562
<pre>
8156381563
<strong>Input:</strong> senate = &quot;RDD&quot;
8156481564
<strong>Output:</strong> &quot;Dire&quot;
81565-
<strong>Explanation:</strong>
81566-
The first senator comes from Radiant and he can just ban the next senator&#39;s right in round 1.
81567-
And the second senator can&#39;t exercise any rights anymore since his right has been banned.
81568-
And the third senator comes from Dire and he can ban the first senator&#39;s right in round 1.
81565+
<strong>Explanation:</strong>
81566+
The first senator comes from Radiant and he can just ban the next senator&#39;s right in round 1.
81567+
And the second senator can&#39;t exercise any rights anymore since his right has been banned.
81568+
And the third senator comes from Dire and he can ban the first senator&#39;s right in round 1.
8156981569
And in round 2, the third senator can just announce the victory since he is the only guy in the senate who can vote.
8157081570
</pre>
8157181571

@@ -81583,7 +81583,14 @@ <h2 id="description">Description</h2>
8158381583
<h2 id="solutions">Solutions</h2>
8158481584
<!-- solution:start -->
8158581585

81586-
<h3 id="solution-1">Solution 1</h3>
81586+
<h3 id="solution-1-queue-simulation">Solution 1: Queue + Simulation</h3>
81587+
<p>We create two queues $qr$ and $qd$ to record the indices of the Radiant and Dire senators, respectively. Then we start the simulation, where in each round we dequeue one senator from each queue and perform different operations based on their factions:</p>
81588+
<ul>
81589+
<li>If the Radiant senator's index is less than the Dire senator's index, the Radiant senator can permanently ban the voting rights of the Dire senator. We add $n$ to the Radiant senator's index and enqueue it back to the end of the queue, indicating that this senator will participate in the next round of voting.</li>
81590+
<li>If the Dire senator's index is less than the Radiant senator's index, the Dire senator can permanently ban the voting rights of the Radiant senator. We add $n$ to the Dire senator's index and enqueue it back to the end of the queue, indicating that this senator will participate in the next round of voting.</li>
81591+
</ul>
81592+
<p>Finally, when there are only senators from one faction left in the queues, the senators from that faction win.</p>
81593+
<p>The time complexity is $O(n)$, and the space complexity is $O(n)$. Here, $n$ is the number of senators.</p>
8158781594
<div class="tabbed-set tabbed-alternate" data-tabs="1:6"><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" /><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></div>
8158881595
<div class="tabbed-content">
8158981596
<div class="tabbed-block">

en/search/search_index.json

Lines changed: 1 addition & 1 deletion
Large diffs are not rendered by default.

0 commit comments

Comments
 (0)