forked from rampatra/Algorithms-and-Data-Structures-in-Java
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathRemoveDuplicatesAndArrangeLetters.java
37 lines (30 loc) · 1.06 KB
/
RemoveDuplicatesAndArrangeLetters.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
package com.rampatra.strings;
import java.util.Set;
import java.util.TreeSet;
import java.util.stream.Collectors;
/**
* @author rampatra
* @since 2019-04-02
*/
public class RemoveDuplicatesAndArrangeLetters {
private static String removeDuplicatesAndArrangeLettersLexicographically(String str) {
Set<Character> charSet = new TreeSet<>();
char[] chars = str.toCharArray();
for (char ch : chars) {
charSet.add(ch);
}
return charSet.toString();
}
private static String removeDuplicatesAndArrangeLettersLexicographically_Java8(String str) {
return str.chars()
.distinct()
.sorted()
.mapToObj(i -> (char) i)
.map(String::valueOf)
.collect(Collectors.joining());
}
public static void main(String[] args) {
System.out.println(removeDuplicatesAndArrangeLettersLexicographically("algo&dsInJava"));
System.out.println(removeDuplicatesAndArrangeLettersLexicographically_Java8("algo&dsInJava"));
}
}