mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-26 23:38:56 +08:00 
			
		
		
		
	first commit
This commit is contained in:
		
							
								
								
									
										33
									
								
								算法题/snapshot-array.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								算法题/snapshot-array.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| <p>Implement a SnapshotArray that supports the following interface:</p> | ||||
|  | ||||
| <ul> | ||||
| 	<li><code>SnapshotArray(int length)</code> initializes an array-like data structure with the given length.  <strong>Initially, each element equals 0</strong>.</li> | ||||
| 	<li><code>void set(index, val)</code> sets the element at the given <code>index</code> to be equal to <code>val</code>.</li> | ||||
| 	<li><code>int snap()</code> takes a snapshot of the array and returns the <code>snap_id</code>: the total number of times we called <code>snap()</code> minus <code>1</code>.</li> | ||||
| 	<li><code>int get(index, snap_id)</code> returns the value at the given <code>index</code>, at the time we took the snapshot with the given <code>snap_id</code></li> | ||||
| </ul> | ||||
|  | ||||
| <p> </p> | ||||
| <p><strong>Example 1:</strong></p> | ||||
|  | ||||
| <pre> | ||||
| <strong>Input:</strong> ["SnapshotArray","set","snap","set","get"] | ||||
| [[3],[0,5],[],[0,6],[0,0]] | ||||
| <strong>Output:</strong> [null,null,0,null,5] | ||||
| <strong>Explanation: </strong> | ||||
| SnapshotArray snapshotArr = new SnapshotArray(3); // set the length to be 3 | ||||
| snapshotArr.set(0,5);  // Set array[0] = 5 | ||||
| snapshotArr.snap();  // Take a snapshot, return snap_id = 0 | ||||
| snapshotArr.set(0,6); | ||||
| snapshotArr.get(0,0);  // Get the value of array[0] with snap_id = 0, return 5</pre> | ||||
|  | ||||
| <p> </p> | ||||
| <p><strong>Constraints:</strong></p> | ||||
|  | ||||
| <ul> | ||||
| 	<li><code>1 <= length <= 50000</code></li> | ||||
| 	<li>At most <code>50000</code> calls will be made to <code>set</code>, <code>snap</code>, and <code>get</code>.</li> | ||||
| 	<li><code>0 <= index < length</code></li> | ||||
| 	<li><code>0 <= snap_id < </code>(the total number of times we call <code>snap()</code>)</li> | ||||
| 	<li><code>0 <= val <= 10^9</code></li> | ||||
| </ul> | ||||
		Reference in New Issue
	
	Block a user