mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-25 23:08:57 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			88 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <p>Given an asynchronous function <code>fn</code> and a time <code>t</code> in milliseconds, return a new <strong>time limited</strong> version of the input function. <code>fn</code> takes arguments provided to the <strong>time limited </strong>function.</p>
 | ||
| 
 | ||
| <p>The <strong>time limited</strong> function should follow these rules:</p>
 | ||
| 
 | ||
| <ul>
 | ||
| 	<li>If the <code>fn</code> completes within the time limit of <code>t</code> milliseconds, the <strong>time limited</strong> function should resolve with the result.</li>
 | ||
| 	<li>If the execution of the <code>fn</code> exceeds the time limit, the <strong>time limited</strong> function should reject with the string <code>"Time Limit Exceeded"</code>.</li>
 | ||
| </ul>
 | ||
| 
 | ||
| <p> </p>
 | ||
| <p><strong class="example">Example 1:</strong></p>
 | ||
| 
 | ||
| <pre>
 | ||
| <strong>Input:</strong> 
 | ||
| fn = async (n) => { 
 | ||
|   await new Promise(res => setTimeout(res, 100)); 
 | ||
|   return n * n; 
 | ||
| }
 | ||
| inputs = [5]
 | ||
| t = 50
 | ||
| <strong>Output:</strong> {"rejected":"Time Limit Exceeded","time":50}
 | ||
| <strong>Explanation:</strong>
 | ||
| const limited = timeLimit(fn, t)
 | ||
| const start = performance.now()
 | ||
| let result;
 | ||
| try {
 | ||
|    const res = await limited(...inputs)
 | ||
|    result = {"resolved": res, "time": Math.floor(performance.now() - start)};
 | ||
| } catch (err) {
 | ||
|    result = {"rejected": err, "time": Math.floor(performance.now() - start)};
 | ||
| }
 | ||
| console.log(result) // Output
 | ||
| 
 | ||
| The provided function is set to resolve after 100ms. However, the time limit is set to 50ms. It rejects at t=50ms because the time limit was reached.
 | ||
| </pre>
 | ||
| 
 | ||
| <p><strong class="example">Example 2:</strong></p>
 | ||
| 
 | ||
| <pre>
 | ||
| <strong>Input:</strong> 
 | ||
| fn = async (n) => { 
 | ||
|   await new Promise(res => setTimeout(res, 100)); 
 | ||
|   return n * n; 
 | ||
| }
 | ||
| inputs = [5]
 | ||
| t = 150
 | ||
| <strong>Output:</strong> {"resolved":25,"time":100}
 | ||
| <strong>Explanation:</strong>
 | ||
| The function resolved 5 * 5 = 25 at t=100ms. The time limit is never reached.
 | ||
| </pre>
 | ||
| 
 | ||
| <p><strong class="example">Example 3:</strong></p>
 | ||
| 
 | ||
| <pre>
 | ||
| <strong>Input:</strong> 
 | ||
| fn = async (a, b) => { 
 | ||
|   await new Promise(res => setTimeout(res, 120)); 
 | ||
|   return a + b; 
 | ||
| }
 | ||
| inputs = [5,10]
 | ||
| t = 150
 | ||
| <strong>Output:</strong> {"resolved":15,"time":120}
 | ||
| <strong>Explanation:</strong>
 | ||
| The function resolved 5 + 10 = 15 at t=120ms. The time limit is never reached.
 | ||
| </pre>
 | ||
| 
 | ||
| <p><strong class="example">Example 4:</strong></p>
 | ||
| 
 | ||
| <pre>
 | ||
| <strong>Input:</strong> 
 | ||
| fn = async () => { 
 | ||
|   throw "Error";
 | ||
| }
 | ||
| inputs = []
 | ||
| t = 1000
 | ||
| <strong>Output:</strong> {"rejected":"Error","time":0}
 | ||
| <strong>Explanation:</strong>
 | ||
| The function immediately throws an error.</pre>
 | ||
| 
 | ||
| <p> </p>
 | ||
| <p><strong>Constraints:</strong></p>
 | ||
| 
 | ||
| <ul>
 | ||
| 	<li><code>0 <= inputs.length <= 10</code></li>
 | ||
| 	<li><code>0 <= t <= 1000</code></li>
 | ||
| 	<li><code>fn</code> returns a promise</li>
 | ||
| </ul>
 |