Home  >  Article  >  Backend Development  >  . All O`one Data Structure

. All O`one Data Structure

Patricia Arquette
Patricia ArquetteOriginal
2024-09-30 06:25:02291browse

. All O`one Data Structure

432. All O`one Data Structure

Difficulty: Hard

Topics: Hash Table, Linked List, Design, Doubly-Linked List

Design a data structure to store the strings' count with the ability to return the strings with minimum and maximum counts.

Implement the AllOne class:

  • AllOne() Initializes the object of the data structure.
  • inc(String key) Increments the count of the string key by 1. If key does not exist in the data structure, insert it with count 1.
  • dec(String key) Decrements the count of the string key by 1. If the count of key is 0 after the decrement, remove it from the data structure. It is guaranteed that key exists in the data structure before the decrement.
  • getMaxKey() Returns one of the keys with the maximal count. If no element exists, return an empty string "".
  • getMinKey() Returns one of the keys with the minimum count. If no element exists, return an empty string "".

Note that each function must run in O(1) average time complexity.

Example 1:

  • Input: ["AllOne", "inc", "inc", "getMaxKey", "getMinKey", "inc", "getMaxKey", "getMinKey"] [[], ["hello"], ["hello"], [], [], ["leet"], [], []]
  • Output: [null, null, null, "hello", "hello", null, "hello", "leet"]
  • Explanation: AllOne allOne = new AllOne(); allOne.inc("hello"); allOne.inc("hello"); allOne.getMaxKey(); // return "hello" allOne.getMinKey(); // return "hello" allOne.inc("leet"); allOne.getMaxKey(); // return "hello" allOne.getMinKey(); // return "leet"

Constraints:

  • 1 <= key.length <= 10
  • key consists of lowercase English letters.
  • It is guaranteed that for each call to dec, key is existing in the data structure.
  • At most 5 * 104 calls will be made to inc, dec, getMaxKey, and getMinKey.

Solution:

We need to implement a data structure that allows incrementing, decrementing, and retrieving keys with the minimum and maximum counts in constant time (O(1)).

Key Insights:

  1. Hash Table (for String Count):
    We need a hash table (counts) that maps each string (key) to its count. This allows for O(1) access when incrementing or decrementing the count.

  2. Doubly Linked List (for Counts):
    To keep track of the minimum and maximum counts, we can use a doubly linked list where each node represents a unique count. The node will store all strings with that count in a set. The linked list will help in retrieving the min and max counts in constant time by keeping track of the head (min) and tail (max) nodes.

  3. Two Hash Maps:

    • A hash map (key_to_node) will map each string (key) to the node in the doubly linked list that stores its count. This allows us to move the key from one count node to another in O(1) time when we increment or decrement the count.
    • Another hash map (counts) will map each count to its corresponding node in the doubly linked list, ensuring we can locate the node for any count in O(1) time.

Plan:

  • inc(key):

    • If the key exists, increase its count by 1 and move it to the next node (create a new node if necessary).
    • If the key does not exist, create a new node with count 1 and insert it.
  • dec(key):

    • Decrease the count of the key by 1.
    • If the count becomes zero, remove the key from the data structure.
  • getMaxKey() and getMinKey():

    • Return the first key from the tail node (max count) or head node (min count) in constant time.

Let's implement this solution in PHP: 432. All O`one Data Structure

inc($key);
 * $obj->dec($key);
 * $ret_3 = $obj->getMaxKey();
 * $ret_4 = $obj->getMinKey();
 */

// Example usage
$allOne = new AllOne();
$allOne->inc("hello");
$allOne->inc("hello");
echo $allOne->getMaxKey(); // returns "hello"
echo $allOne->getMinKey(); // returns "hello"
$allOne->inc("leet");
echo $allOne->getMaxKey(); // returns "hello"
echo $allOne->getMinKey(); // returns "leet"
?>




Explanation:

  1. Data Structure:

    • key_to_node: Maps each key to the corresponding node in the doubly linked list.
    • counts: Maps each count to its corresponding node in the doubly linked list.
    • head and tail: Dummy head and tail nodes for easier manipulation of the doubly linked list.
  2. Methods:

    • inc($key): If the key exists, it increments its count and moves it to the appropriate node in the list. If not, it inserts it with count 1.
    • dec($key): Decreases the key’s count and either removes it or moves it to the appropriate node.
    • getMaxKey(): Returns the key from the node at the tail of the doubly linked list (max count).
    • getMinKey(): Returns the key from the node at the head of the doubly linked list (min count).

Complexity:

  • All operations are designed to run in O(1) average time complexity.

Let me know if you need further clarifications!

Contact Links

If you found this series helpful, please consider giving the repository a star on GitHub or sharing the post on your favorite social networks ?. Your support would mean a lot to me!

If you want more helpful content like this, feel free to follow me:

  • LinkedIn
  • GitHub

The above is the detailed content of . All O`one Data Structure. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn