Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
Skip to content

Commit 4681e47

Browse files
add 2165
1 parent 2b3ef66 commit 4681e47

File tree

2 files changed

+69
-0
lines changed

2 files changed

+69
-0
lines changed

README.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,7 @@ _If you like this project, please leave me a star._ ★
88

99
| # | Title | Solutions | Video | Difficulty | Tag
1010
|-----|----------------|---------------|--------|-------------|-------------
11+
|2165|[Smallest Value of the Rearranged Number](https://leetcode.com/problems/smallest-value-of-the-rearranged-number/)|[Java](../master/src/main/java/com/fishercoder/solutions/_2165.java) ||Medium||
1112
|2164|[Sort Even and Odd Indices Independently](https://leetcode.com/problems/sort-even-and-odd-indices-independently/)|[Java](../master/src/main/java/com/fishercoder/solutions/_2164.java) ||Easy||
1213
|2161|[Partition Array According to Given Pivot](https://leetcode.com/problems/partition-array-according-to-given-pivot/)|[Java](../master/src/main/java/com/fishercoder/solutions/_2161.java) ||Medium||
1314
|2160|[Minimum Sum of Four Digit Number After Splitting Digits](https://leetcode.com/problems/minimum-sum-of-four-digit-number-after-splitting-digits/)|[Java](../master/src/main/java/com/fishercoder/solutions/_2160.java) ||Easy||
Lines changed: 68 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,68 @@
1+
package com.fishercoder.solutions;
2+
3+
import java.util.*;
4+
5+
public class _2165 {
6+
public static class Solution1 {
7+
public long smallestNumber(long num) {
8+
if (num == 0) {
9+
return num;
10+
}
11+
boolean negative = num < 0;
12+
TreeMap<Integer, Integer> treeMap = new TreeMap<>();
13+
while (num != 0) {
14+
int digit = (int) Math.abs(num % 10);
15+
treeMap.put(digit, treeMap.getOrDefault(digit, 0) + 1);
16+
num /= 10;
17+
}
18+
if (!negative) {
19+
if (treeMap.firstKey() == 0) {
20+
int zeroCount = treeMap.get(0);
21+
treeMap.remove(0);
22+
StringBuilder sb = new StringBuilder();
23+
int time = 0;
24+
for (int key : treeMap.keySet()) {
25+
int count = treeMap.get(key);
26+
time++;
27+
if (time == 1) {
28+
sb.append(key);
29+
while (zeroCount > 0) {
30+
sb.append(0);
31+
zeroCount--;
32+
}
33+
count--;
34+
}
35+
while (count > 0) {
36+
sb.append(key);
37+
count--;
38+
}
39+
}
40+
return Long.parseLong(sb.toString());
41+
} else {
42+
StringBuilder sb = new StringBuilder();
43+
for (int key : treeMap.keySet()) {
44+
int count = treeMap.get(key);
45+
while (count > 0) {
46+
sb.append(key);
47+
count--;
48+
}
49+
}
50+
return Long.parseLong(sb.toString());
51+
}
52+
} else {
53+
Set<Integer> keys = treeMap.keySet();
54+
List<Integer> sorted = new ArrayList<>(keys);
55+
Collections.sort(sorted, Collections.reverseOrder());
56+
StringBuilder sb = new StringBuilder();
57+
for (int i = 0; i < sorted.size(); i++) {
58+
int count = treeMap.get(sorted.get(i));
59+
while (count > 0) {
60+
sb.append(sorted.get(i));
61+
count--;
62+
}
63+
}
64+
return -Long.parseLong(sb.toString());
65+
}
66+
}
67+
}
68+
}

0 commit comments

Comments
 (0)