Class MajorityChecker


  • public class MajorityChecker
    extends Object
    1157 - Online Majority Element In Subarray\. Hard Design a data structure that efficiently finds the **majority element** of a given subarray. The **majority element** of a subarray is an element that occurs `threshold` times or more in the subarray. Implementing the `MajorityChecker` class: * `MajorityChecker(int[] arr)` Initializes the instance of the class with the given array `arr`. * `int query(int left, int right, int threshold)` returns the element in the subarray `arr[left...right]` that occurs at least `threshold` times, or `-1` if no such element exists. **Example 1:** **Input** ["MajorityChecker", "query", "query", "query"] [[[1, 1, 2, 2, 1, 1]], [0, 5, 4], [0, 3, 3], [2, 3, 2]] **Output:** [null, 1, -1, 2] **Explanation:** MajorityChecker majorityChecker = new MajorityChecker([1, 1, 2, 2, 1, 1]); majorityChecker.query(0, 5, 4); // return 1 majorityChecker.query(0, 3, 3); // return -1 majorityChecker.query(2, 3, 2); // return 2 **Constraints:** * 1 <= arr.length <= 2 * 104 * 1 <= arr[i] <= 2 * 104 * `0 <= left <= right < arr.length` * `threshold <= right - left + 1` * `2 * threshold > right - left + 1` * At most 104 calls will be made to `query`.
    • Constructor Detail

      • MajorityChecker

        public MajorityChecker​(int[] arr)
    • Method Detail

      • query

        public int query​(int left,
                         int right,
                         int threshold)