Easy
Given an integer n
, find the digit that occurs least frequently in its decimal representation. If multiple digits have the same frequency, choose the smallest digit.
Return the chosen digit as an integer.
The frequency of a digit x
is the number of times it appears in the decimal representation of n
.
Example 1:
Input: n = 1553322
Output: 1
Explanation:
The least frequent digit in n
is 1, which appears only once. All other digits appear twice.
Example 2:
Input: n = 723344511
Output: 2
Explanation:
The least frequent digits in n
are 7, 2, and 5; each appears only once.
Constraints:
1 <= n <= 231 - 1
public class Solution {
public int getLeastFrequentDigit(int n) {
int[] freq = new int[10];
String numStr = String.valueOf(n);
for (char c : numStr.toCharArray()) {
freq[c - '0']++;
}
int minFreq = Integer.MAX_VALUE;
int result = -1;
for (int d = 0; d <= 9; d++) {
if (freq[d] == 0) {
continue;
}
if (freq[d] < minFreq) {
minFreq = freq[d];
result = d;
} else if (freq[d] == minFreq && d < result) {
result = d;
}
}
return result;
}
}