Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/344.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 按自然顺序排序字符串数组并忽略空格_Java_Android - Fatal编程技术网

Java 按自然顺序排序字符串数组并忽略空格

Java 按自然顺序排序字符串数组并忽略空格,java,android,Java,Android,我发现这个示例代码发布在这个论坛上,非常好用。 它可以帮助我按照“自然顺序”对磁盘上的文件名进行排序,即人类喜欢看到的方式: 文件1 文件2 文件3 文件11 如果只是正常的(ascii)排序,file11将位于file1之后和file2之前 问题是如何改进这段代码,并设置一个可以忽略空格的选项,这在读取长列表中的文件名时是非常有用的排序类型,如: 文件1 文件1 文件2 文件3 这是密码 Collections.sort(myStringArrayList,

我发现这个示例代码发布在这个论坛上,非常好用。 它可以帮助我按照“自然顺序”对磁盘上的文件名进行排序,即人类喜欢看到的方式:

  • 文件1

    文件2

    文件3

    文件11

如果只是正常的(ascii)排序,file11将位于file1之后和file2之前

问题是如何改进这段代码,并设置一个可以忽略空格的选项,这在读取长列表中的文件名时是非常有用的排序类型,如:

  • 文件1

    文件1

    文件2

    文件3

这是密码

Collections.sort(myStringArrayList, 
                 new AlphanumComparator(String.CASE_INSENSITIVE_ORDER));



 /*
 * The Alphanum Algorithm is an improved sorting algorithm for strings 
 * containing numbers.  Instead of sorting numbers in ASCII order like 
 * a standard sort, this algorithm sorts numbers in numeric order. 
 * 
 * The Alphanum Algorithm is discussed at http://www.DaveKoelle.com 
 * 
 * 
 * This library is free software; you can redistribute it and/or 
 * modify it under the terms of the GNU Lesser General Public 
 * License as published by the Free Software Foundation; either 
 * version 2.1 of the License, or any later version. 
 * 
 * This library is distributed in the hope that it will be useful, 
 * but WITHOUT ANY WARRANTY; without even the implied warranty of 
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU 
 * Lesser General Public License for more details. 
 * 
 * You should have received a copy of the GNU Lesser General Public 
 * License along with this library; if not, write to the Free Software 
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA 
 * 
 */ 

import java.util.Comparator; 

/** 
 * This is an updated version with enhancements made by Daniel Migowski, 
 * Andre Bogus, and David Koelle 
 * 
 * To convert to use Templates (Java 1.5+): 
 *   - Change "implements Comparator" to "implements Comparator<String>" 
 *   - Change "compare(Object o1, Object o2)" to "compare(String s1, String s2)" 
 *   - Remove the type checking and casting in compare(). 
 * 
 * To use this class: 
 *   Use the static "sort" method from the java.util.Collections class: 
 *   Collections.sort(your list, new AlphanumComparator()); 
 */ 
public class AlphanumComparator implements Comparator<String> 
{ 
    private Comparator<String> comparator = new NaturalComparator(); 

    public AlphanumComparator(Comparator<String> comparator) { 
        this.comparator = comparator; 
    } 

    public AlphanumComparator() { 

    } 

    private final boolean isDigit(char ch) 
    { 
        return ch >= 48 && ch <= 57; 
    } 

    /** Length of string is passed in for improved efficiency (only need to calculate it once) **/ 
    private final String getChunk(String s, int slength, int marker) 
    { 
        StringBuilder chunk = new StringBuilder(); 
        char c = s.charAt(marker); 
        chunk.append(c); 
        marker++; 
        if (isDigit(c)) 
        { 
            while (marker < slength) 
            { 
                c = s.charAt(marker); 
                if (!isDigit(c)) 
                    break; 
                chunk.append(c); 
                marker++; 
            } 
        } else 
        { 
            while (marker < slength) 
            { 
                c = s.charAt(marker); 
                if (isDigit(c)) 
                    break; 
                chunk.append(c); 
                marker++; 
            } 
        } 
        return chunk.toString(); 
    } 

    public int compare(String s1, String s2) 
    { 

        int thisMarker = 0; 
        int thatMarker = 0; 
        int s1Length = s1.length(); 
        int s2Length = s2.length(); 

        while (thisMarker < s1Length && thatMarker < s2Length) 
        { 
            String thisChunk = getChunk(s1, s1Length, thisMarker); 
            thisMarker += thisChunk.length(); 

            String thatChunk = getChunk(s2, s2Length, thatMarker); 
            thatMarker += thatChunk.length(); 

            // If both chunks contain numeric characters, sort them numerically 
            int result = 0; 
            if (isDigit(thisChunk.charAt(0)) && isDigit(thatChunk.charAt(0))) 
            { 
                // Simple chunk comparison by length. 
                int thisChunkLength = thisChunk.length(); 
                result = thisChunkLength - thatChunk.length(); 
                // If equal, the first different number counts 
                if (result == 0) 
                { 
                    for (int i = 0; i < thisChunkLength; i++) 
                    { 
                        result = thisChunk.charAt(i) - thatChunk.charAt(i); 
                        if (result != 0) 
                        { 
                            return result; 
                        } 
                    } 
                } 
            } else 
            { 
                result = comparator.compare(thisChunk, thatChunk); 
            } 

            if (result != 0) 
                return result; 
        } 

        return s1Length - s2Length; 
    } 

    private static class NaturalComparator implements Comparator<String> { 
        public int compare(String o1, String o2) { 
            return o1.compareTo(o2); 
        } 
    } 
Collections.sort(myStringArrayList,
新的AlphanumComparator(String.CASE_-INSENSITIVE_-ORDER));
/*
*Alphanum算法是一种改进的字符串排序算法
*包含数字。而不是像这样按ASCII顺序对数字进行排序
*作为一种标准排序,该算法按数字顺序对数字进行排序。
* 
*Alphanum算法在http://www.DaveKoelle.com 
* 
* 
*这个图书馆是免费软件;您可以重新分发它和/或
*根据GNU小公众的条款对其进行修改
*自由软件基金会发布的许可证;任何一个
*许可证的2.1版或任何更高版本。
* 
*这个图书馆的发行是希望它会有用,
*但无任何保证;甚至没有任何关于
*适销性或适合某一特定目的。见GNU
*有关更多详细信息,请参阅较低的通用公共许可证。
* 
*您应该已经收到GNU Lesser General Public的副本
*与此库一起使用的许可证;如果没有,请写信给自由软件
*基金会,公司,51富兰克林街,第五楼,波士顿,美国02110-1301
* 
*/ 
导入java.util.Comparator;
/** 
*这是由Daniel Migowski改进的更新版本,
*安德烈·博格斯和大卫·科勒
* 
*要转换为使用模板(Java 1.5+),请执行以下操作:
*-将“implements Comparator”更改为“implements Comparator”
*-将“比较(对象o1,对象o2)”更改为“比较(字符串s1,字符串s2)”
*-在compare()中移除类型检查和强制转换。
* 
*要使用此类,请执行以下操作:
*使用java.util.Collections类中的静态“sort”方法:
*排序(您的列表,新的AlphanumComparator());
*/ 
公共类AlphanumComparator实现比较器
{ 
专用比较器比较器=新的自然比较器();
公共字母计算器(比较器){
这个比较器=比较器;
} 
公共AlphanumComparator(){
} 
专用最终布尔值isDigit(字符ch)
{ 
返回ch>=48&&ch可以通过在getChunck()方法中添加if c!=''来实现

上面的代码不会向块添加空间。

可以通过在getChunck()方法中添加if c!=''来实现

Collections.sort(myStringArrayList, new Comparator<String>() {


@Override
        public int compare(String o1, String o2) {
            int temp = o1.length() - o2.length();
            o1 = o1.replaceAll(" ", "");
            o2 = o2.replaceAll(" ", "");
            int compareTo = o1.compareTo(o2);
            if(compareTo == 0){
                return temp;
            }
            else{
                return compareTo;
            }
        }
    });
上面的代码不会为区块添加空间。

Collections.sort(myStringArrayList,newcomparator()){
Collections.sort(myStringArrayList, new Comparator<String>() {


@Override
        public int compare(String o1, String o2) {
            int temp = o1.length() - o2.length();
            o1 = o1.replaceAll(" ", "");
            o2 = o2.replaceAll(" ", "");
            int compareTo = o1.compareTo(o2);
            if(compareTo == 0){
                return temp;
            }
            else{
                return compareTo;
            }
        }
    });
@凌驾 公共整数比较(字符串o1、字符串o2){ int temp=o1.length()-o2.length(); o1=o1.replaceAll(“,”); o2=o2.replaceAll(“,”); int compareTo=o1。compareTo(o2); 如果(比较=0){ 返回温度; } 否则{ 返回比较; } } });
比较器还可用于控制某些数据结构(如排序集或排序映射)的顺序,或为没有自然排序的对象集合提供排序。

collections.sort(myStringArrayList,new Comparator(){
@凌驾
公共整数比较(字符串o1、字符串o2){
int temp=o1.length()-o2.length();
o1=o1.replaceAll(“,”);
o2=o2.replaceAll(“,”);
int compareTo=o1。compareTo(o2);
如果(比较=0){
返回温度;
}
否则{
返回比较;
}
}
});

比较器还可用于控制某些数据结构(如排序集或排序映射)的顺序,或为没有自然排序的对象集合提供排序。

一个简单的解决方案应该通过您介绍的四种情况的测试,即通过相同代码的构造函数和自定义比较器,如下所示:

 public class SpaceInsensitiveComparator implements Comparator<String> {   
    public int compare(String o1, String o2) {   
        return o1.trim().compareTo(o2.trim());   
    }   
 } 
公共类SpaceInsensitiveComparator实现比较器{
公共整数比较(字符串o1,字符串o2){
返回o1.trim().compareTo(o2.trim());
}   
} 
或对于案例不敏感:

 public class SpaceInsensitiveComparator implements Comparator<String> {   
    public int compare(String o1, String o2) {   
        return String.CASE_INSENSITIVE_ORDER.compare(o1.trim(), o2.trim());   
    }   
 } 
公共类SpaceInsensitiveComparator实现比较器{
公共整数比较(字符串o1,字符串o2){
返回字符串。不区分大小写。\u顺序。比较(o1.trim(),o2.trim());
}   
} 

一个简单的解决方案应该通过您介绍的四个案例的测试,即通过同一代码的构造函数和自定义比较器,如下所示:

 public class SpaceInsensitiveComparator implements Comparator<String> {   
    public int compare(String o1, String o2) {   
        return o1.trim().compareTo(o2.trim());   
    }   
 } 
公共类SpaceInsensitiveComparator实现比较器{
公共整数比较(字符串o1,字符串o2){
返回o1.trim().compareTo(o2.trim());
}   
} 
或对于案例不敏感:

 public class SpaceInsensitiveComparator implements Comparator<String> {   
    public int compare(String o1, String o2) {   
        return String.CASE_INSENSITIVE_ORDER.compare(o1.trim(), o2.trim());   
    }   
 } 
公共类SpaceInsensitiveComparator实现比较器{
公共整数比较(字符串o1,字符串o2){
返回字符串。不区分大小写。\u顺序。比较(o1.trim(),o2.trim());
}   
} 

不,它没有区别也没有区别我已将此代码放在NaturalComparator中,在我的问题代码的底部,但它没有区别,“级别3”位于“级别2”之前,而不是after@Lumis,尝试将JCN的比较器作为NaturalComparator构造函数中的比较器传递租金结果,de