mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-25 06:48:57 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			47 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <p>There is an authentication system that works with authentication tokens. For each session, the user will receive a new authentication token that will expire <code>timeToLive</code> seconds after the <code>currentTime</code>. If the token is renewed, the expiry time will be <b>extended</b> to expire <code>timeToLive</code> seconds after the (potentially different) <code>currentTime</code>.</p>
 | |
| 
 | |
| <p>Implement the <code>AuthenticationManager</code> class:</p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>AuthenticationManager(int timeToLive)</code> constructs the <code>AuthenticationManager</code> and sets the <code>timeToLive</code>.</li>
 | |
| 	<li><code>generate(string tokenId, int currentTime)</code> generates a new token with the given <code>tokenId</code> at the given <code>currentTime</code> in seconds.</li>
 | |
| 	<li><code>renew(string tokenId, int currentTime)</code> renews the <strong>unexpired</strong> token with the given <code>tokenId</code> at the given <code>currentTime</code> in seconds. If there are no unexpired tokens with the given <code>tokenId</code>, the request is ignored, and nothing happens.</li>
 | |
| 	<li><code>countUnexpiredTokens(int currentTime)</code> returns the number of <strong>unexpired</strong> tokens at the given currentTime.</li>
 | |
| </ul>
 | |
| 
 | |
| <p>Note that if a token expires at time <code>t</code>, and another action happens on time <code>t</code> (<code>renew</code> or <code>countUnexpiredTokens</code>), the expiration takes place <strong>before</strong> the other actions.</p>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Example 1:</strong></p>
 | |
| <img alt="" src="https://assets.leetcode.com/uploads/2021/02/25/copy-of-pc68_q2.png" style="width: 500px; height: 287px;" />
 | |
| <pre>
 | |
| <strong>Input</strong>
 | |
| ["AuthenticationManager", "<code>renew</code>", "generate", "<code>countUnexpiredTokens</code>", "generate", "<code>renew</code>", "<code>renew</code>", "<code>countUnexpiredTokens</code>"]
 | |
| [[5], ["aaa", 1], ["aaa", 2], [6], ["bbb", 7], ["aaa", 8], ["bbb", 10], [15]]
 | |
| <strong>Output</strong>
 | |
| [null, null, null, 1, null, null, null, 0]
 | |
| 
 | |
| <strong>Explanation</strong>
 | |
| AuthenticationManager authenticationManager = new AuthenticationManager(5); // Constructs the AuthenticationManager with <code>timeToLive</code> = 5 seconds.
 | |
| authenticationManager.<code>renew</code>("aaa", 1); // No token exists with tokenId "aaa" at time 1, so nothing happens.
 | |
| authenticationManager.generate("aaa", 2); // Generates a new token with tokenId "aaa" at time 2.
 | |
| authenticationManager.<code>countUnexpiredTokens</code>(6); // The token with tokenId "aaa" is the only unexpired one at time 6, so return 1.
 | |
| authenticationManager.generate("bbb", 7); // Generates a new token with tokenId "bbb" at time 7.
 | |
| authenticationManager.<code>renew</code>("aaa", 8); // The token with tokenId "aaa" expired at time 7, and 8 >= 7, so at time 8 the <code>renew</code> request is ignored, and nothing happens.
 | |
| authenticationManager.<code>renew</code>("bbb", 10); // The token with tokenId "bbb" is unexpired at time 10, so the <code>renew</code> request is fulfilled and now the token will expire at time 15.
 | |
| authenticationManager.<code>countUnexpiredTokens</code>(15); // The token with tokenId "bbb" expires at time 15, and the token with tokenId "aaa" expired at time 7, so currently no token is unexpired, so return 0.
 | |
| </pre>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Constraints:</strong></p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>1 <= timeToLive <= 10<sup>8</sup></code></li>
 | |
| 	<li><code>1 <= currentTime <= 10<sup>8</sup></code></li>
 | |
| 	<li><code>1 <= tokenId.length <= 5</code></li>
 | |
| 	<li><code>tokenId</code> consists only of lowercase letters.</li>
 | |
| 	<li>All calls to <code>generate</code> will contain unique values of <code>tokenId</code>.</li>
 | |
| 	<li>The values of <code>currentTime</code> across all the function calls will be <strong>strictly increasing</strong>.</li>
 | |
| 	<li>At most <code>2000</code> calls will be made to all functions combined.</li>
 | |
| </ul>
 |