1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-01-11 02:58:13 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
leetcode-problemset/leetcode/problem/interval-cancellation.html

106 lines
3.6 KiB
HTML
Raw Normal View History

2023-12-09 18:42:21 +08:00
<p>Given a function <code>fn</code>, an array of arguments&nbsp;<code>args</code>, and&nbsp;an interval time <code>t</code>, return a cancel function <code>cancelFn</code>.</p>
<p>The function <code>fn</code> should be called with <code>args</code> immediately and then called again every&nbsp;<code>t</code> milliseconds&nbsp;until&nbsp;<code>cancelFn</code>&nbsp;is called at <code>cancelTimeMs</code> ms.</p>
2023-06-12 23:05:37 +08:00
<p>&nbsp;</p>
<p><strong class="example">Example 1:</strong></p>
<pre>
2023-12-09 18:42:21 +08:00
<strong>Input:</strong> fn = (x) =&gt; x * 2, args = [4], t = 35
2023-06-12 23:05:37 +08:00
<strong>Output:</strong>
[
{&quot;time&quot;: 0, &quot;returned&quot;: 8},
2023-12-09 18:42:21 +08:00
{&quot;time&quot;: 35, &quot;returned&quot;: 8},
{&quot;time&quot;: 70, &quot;returned&quot;: 8},
{&quot;time&quot;: 105, &quot;returned&quot;: 8},
{&quot;time&quot;: 140, &quot;returned&quot;: 8},
{&quot;time&quot;: 175, &quot;returned&quot;: 8}
2023-06-12 23:05:37 +08:00
]
2023-12-09 18:42:21 +08:00
<strong>Explanation:</strong>
const result = [];
const fn = (x) =&gt; x * 2;
const cancelTimeMs = 190;
const start = performance.now();
const log = (...argsArr) =&gt; {
const diff = Math.floor(performance.now() - start);
result.push({&quot;time&quot;: diff, &quot;returned&quot;: fn(...argsArr)});
}
2023-06-12 23:05:37 +08:00
2023-12-09 18:42:21 +08:00
const cancel = cancellable(log, [4], 35);
setTimeout(cancel, cancelTimeMs);
2023-06-12 23:05:37 +08:00
2023-12-09 18:42:21 +08:00
setTimeout(() =&gt; {
console.log(result); // Output
}, cancelTimeMs + 50)
Every 35ms, fn(4) is called. Until t=190ms, then it is cancelled.
2023-06-12 23:05:37 +08:00
1st fn call is at 0ms. fn(4) returns 8.
2023-12-09 18:42:21 +08:00
2nd fn call is at 35ms. fn(4) returns 8.
3rd fn call is at 70ms. fn(4) returns 8.
4th fn call is at&nbsp;105ms. fn(4) returns 8.
5th fn call is at 140ms. fn(4) returns 8.
6th fn call is at 175ms. fn(4) returns 8.
Cancelled at 190ms
2023-06-12 23:05:37 +08:00
</pre>
<p><strong class="example">Example 2:</strong></p>
<pre>
2023-12-09 18:42:21 +08:00
<strong>Input:</strong> fn = (x1, x2) =&gt; (x1 * x2), args = [2, 5], t = 30
2023-06-12 23:05:37 +08:00
<strong>Output:</strong>
[
{&quot;time&quot;: 0, &quot;returned&quot;: 10},
2023-12-09 18:42:21 +08:00
{&quot;time&quot;: 30, &quot;returned&quot;: 10},
{&quot;time&quot;: 60, &quot;returned&quot;: 10},
{&quot;time&quot;: 90, &quot;returned&quot;: 10},
{&quot;time&quot;: 120, &quot;returned&quot;: 10},
{&quot;time&quot;: 150, &quot;returned&quot;: 10}
2023-06-12 23:05:37 +08:00
]
2023-12-09 18:42:21 +08:00
<strong>Explanation:</strong>
const cancelTimeMs = 165;
Every 30ms, fn(2, 5) is called. Until t=165ms, then it is cancelled.
2023-06-12 23:05:37 +08:00
1st fn call is at 0ms&nbsp;
2023-12-09 18:42:21 +08:00
2nd fn call is at 30ms&nbsp;
3rd fn call is at 60ms&nbsp;
4th fn call is at&nbsp;90ms&nbsp;
5th fn call is at 120ms&nbsp;
6th fn call is at 150ms
Cancelled at 165ms
2023-06-12 23:05:37 +08:00
</pre>
<p><strong class="example">Example 3:</strong></p>
<pre>
2023-12-09 18:42:21 +08:00
<strong>Input:</strong> fn = (x1, x2, x3) =&gt; (x1 + x2 + x3), args = [5, 1, 3], t = 50
2023-06-12 23:05:37 +08:00
<strong>Output:</strong>
[
{&quot;time&quot;: 0, &quot;returned&quot;: 9},
{&quot;time&quot;: 50, &quot;returned&quot;: 9},
{&quot;time&quot;: 100, &quot;returned&quot;: 9},
{&quot;time&quot;: 150, &quot;returned&quot;: 9}
]
2023-12-09 18:42:21 +08:00
<strong>Explanation:</strong>
const cancelTimeMs = 180;
Every 50ms, fn(5, 1, 3) is called. Until t=180ms, then it is cancelled.
2023-06-12 23:05:37 +08:00
1st fn call is at 0ms
2nd fn call is at 50ms
3rd fn call is at 100ms
4th fn call is at&nbsp;150ms
Cancelled at 180ms
</pre>
<p>&nbsp;</p>
<p><strong>Constraints:</strong></p>
<ul>
2023-12-09 18:42:21 +08:00
<li><code>fn</code> is a function</li>
<li><code>args</code> is a valid JSON array</li>
2023-06-12 23:05:37 +08:00
<li><code>1 &lt;= args.length &lt;= 10</code></li>
2023-12-09 18:42:21 +08:00
<li><code><font face="monospace">30 &lt;= t &lt;= 100</font></code></li>
<li><code><font face="monospace">10 &lt;= </font>cancelTimeMs<font face="monospace"> &lt;= 500</font></code></li>
2023-06-12 23:05:37 +08:00
</ul>