Я хотел бы поместить букву «h» между «u» и «v». Я нашел решение, но я думаю, что это можно решить короче и красивее.Пользовательский алфавитный заказ
public class CustomStringSort
{
public static void main(String[] args)
{
String[] abc = "abcdefghijklmnopqrstuvwxyz".split("");
List<String> letters = Arrays.asList(abc);
Collections.sort(letters, new MyStringComparator());
for(String letter : letters)
{
System.out.println(letter);
}
}
static class MyStringComparator implements Comparator<String>
{
@Override
public int compare(String o1, String o2)
{
if(o1.equals("h") && o2.compareTo("u") <= 0)
{
return 1;
}
if(o1.equals("h") && o2.compareTo("v") >= 0)
{
return -1;
}
if(o2.equals("h") && o1.compareTo("u") <= 0)
{
return -1;
}
if(o2.equals("h") && o1.compareTo("v") >= 0)
{
return 1;
}
return o1.compareTo(o2);
}
}
}
Рассмотрят http://codereview.stackexchange.com/ –
, как вы делаете кажется правильным , – mtk
Будьте осторожны, вы только обмениваетесь строчными буквами. Кроме того, вам нужно сравнить строки или символы? – Luciano