-1

我可以在java中获得任何简单的方法,我可以按顺序排列字母

a < aa < aaa < aaaa
a < b < ab < ba < aba

String.compareTo 方法将按以下格式排列数据。因此不会满足我的目的 a < aa < aaa < b < ab < ba

请帮忙!!!

4

3 回答 3

6

您可以使用Comparator

检查这个:

import java.util.Comparator;
public class SComparator implements Comparator<String> {

    @Override
    public int compare(String s1, String s2) {
        if(s1.length() != s2.length()){
            return s1.length() - s2.length();
        }
        return s1.compareTo(s2);
    }

}

然后,您可以像这样使用它:

ArrayList<String> L = new ArrayList<String>();
// ...
Collections.sort(L, new SComparator());
于 2013-08-27T07:53:51.513 回答
1

您可以使用比较器来比较字符串长度并一起使用 compareTo

        public int compare( String o1, String o2 )
        {
            if( o1.length() > o2.length() )
            {
                return 1;
            }
            else if( o1.length() < o2.length() )
            {
                return -1;
            }
            return o1.compareTo( o2 );
        }
于 2013-08-27T07:55:23.257 回答
0

你也可以通过排序来解决这个问题。

String[] words = {"going", "went", "go", "how", "jam"};    
Arrays.sort(arr);

输出:

go < going < how < jam < went
于 2013-08-28T15:16:03.990 回答