LeetCode 1133. Largest Unique Number Solution in Java, C++, Python & More | Explanation + Code

CoderIndeed
0
1133. Largest Unique Number

Description

Given an integer array nums, return the largest integer that only occurs once. If no integer occurs once, return -1.

 

Example 1:

Input: nums = [5,7,3,9,4,9,8,3,1]
Output: 8
Explanation: The maximum integer in the array is 9 but it is repeated. The number 8 occurs only once, so it is the answer.

Example 2:

Input: nums = [9,9,8,8]
Output: -1
Explanation: There is no number that occurs only once.

 

Constraints:

  • 1 <= nums.length <= 2000
  • 0 <= nums[i] <= 1000

Solutions

Solution 1: Counting + Reverse Traversal

Given the data range in the problem, we can use an array of length 1001 to count the occurrence of each number. Then, we traverse the array in reverse order to find the first number that appears only once. If no such number is found, we return -1.

The time complexity is O(n + M), and the space complexity is O(M). Here, n is the length of the array, and M is the maximum number that appears in the array. In this problem, M ≤ 1000.

PythonJavaC++GoTypeScriptJavaScript
class Solution: def largestUniqueNumber(self, nums: List[int]) -> int: cnt = Counter(nums) return max((x for x, v in cnt.items() if v == 1), default=-1)(code-box)

Post a Comment

0Comments

Post a Comment (0)

#buttons=(Accept !) #days=(20)

Our website uses cookies to enhance your experience. Check Now
Accept !