chenyc
2025-12-09 65e034683b28d799e73c7d7e5e4769fab5b9bc9c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
export declare class NumberAllocator {
  /**
   * NumberAllocator constructor.
   * The all numbers are set to vacant status.
   * Time Complexity O(1)
   * @constructor
   * @param {number} min  - The maximum number of allocatable. The number must be integer.
   * @param {number} maxh - The minimum number of allocatable. The number must be integer.
   */
  constructor (min: number, max: number)
 
  /**
   * Get the first vacant number. The status of the number is not updated.
   * Time Complexity O(1)
   * @return {number} - The first vacant number. If all numbers are occupied, return null.
   *                    When alloc() is called then the same value will be allocated.
   */
  public firstVacant (): number | null
 
  /**
   * Allocate the first vacant number. The number become occupied status.
   * Time Complexity O(1)
   * @return {number} - The first vacant number. If all numbers are occupied, return null.
   */
  public alloc (): number | null
 
  /**
   * Use the number. The number become occupied status.
   * If the number has already been occupied, then return false.
   * Time Complexity O(logN) : N is the number of intervals (not numbers)
   * @param {number} num - The number to request use.
   * @return {Boolean} - If `num` was not occupied, then return true, otherwise return false.
   */
  public use (num: number): Boolean
 
  /**
   * Deallocate the number. The number become vacant status.
   * Time Complexity O(logN) : N is the number of intervals (not numbers)
   * @param {number} num - The number to deallocate. The number must be occupied status.
   *                       In other words, the number must be allocated by alloc() or occupied be use().
   */
  public free (num: number): void
 
  /**
   * Clear all occupied numbers.
   * The all numbers are set to vacant status.
   * Time Complexity O(1)
   */
  public clear (): void
 
  /**
   * Get the number of intervals. Interval is internal structure of this library.
   * This function is for debugging.
   * Time Complexity O(1)
   * @return {number} - The number of intervals.
   */
  public intervalCount (): number
 
  /**
   * Dump the internal structor of the library.
   * This function is for debugging.
   * Time Complexity O(N) : N is the number of intervals (not numbers)
   */
  dump (): void
}