java - 根据每个字符串的子字符串对 String ArrayList 的一半进行排序

标签 java string sorting arraylist comparator

例如,我有一个大小为 String ArrayList 的字符串

[12、10L、10、10R、10S、10L]

输出应该是

[10S、10R、10L、10、12]

所以基本上尺寸必须首先按数字排序 - (1,2,3,4,5 ...等)然后按字母排序。

我设法对数字进行排序,因此上面输入的当前输出是

10L、10、10R、10S、10L、12

如果缺少一个字母,则它是最大的(参见上面的输出 - 10 在 10L - 10S < 10R < 10L < 10 < 12 之后。)

我应该如何编写一个允许我执行此操作的比较器?

考虑一个输入数组,大小。该数组包含 AB 格式的产品尺寸,其中:

A 是强制整数 B 是 [S,R,L] 中的可选字符 尺寸必须首先按 A 从小到大排序,然后按 S 的顺序按 B 排序

最佳答案

如果它适用于您的测试用例,请尝试此操作。如果需要,我们随时可以对其进行完善。 (添加了辅助方法)

List<String> list = new ArrayList<>(Arrays.asList("12","10L","10","10R","10S","10L","14L","14","8","12S"));
List<String> orderArray = new ArrayList<>(Arrays.asList("S", "R", "L"));

List<String> sortedList = list.stream()
            .sorted(Comparator.comparing(str -> Integer.parseInt(((String)str).replaceAll("[A-Z]*","")))
                    .thenComparing(str -> getAnInt(orderArray, (String) str)))
            .distinct()
            .collect(Collectors.toList());

System.out.println(sortedList);

private int getAnInt(List<String> orderArray, String str) {
    int i = orderArray.indexOf(str.substring(str.length() - 1));
    if (i == -1) return Integer.MAX_VALUE;
    return i;
}

输出:[8、10S、10R、10L、10、12S、12、14L、14]

如果您不想使用流:

List<String> list = new ArrayList<>(Arrays.asList("12","10L","10","10R","10S","10L","14L","14","8","12S"));
List<String> orderArray = new ArrayList<>(Arrays.asList("S", "R", "L"));

list.sort(new Comparator<String>() {
        @Override
        public int compare(String lhs, String rhs) {
            int lInt = Integer.parseInt(lhs.replaceAll("[A-Z]*", ""));
            int rInt = Integer.parseInt(rhs.replaceAll("[A-Z]*", ""));
            if (lInt != rInt) {
               return lInt - rInt;
            } else {
                return getAnInt(orderArray, lhs) - getAnInt(orderArray, rhs);
            }
        }
    });

System.out.println(list);

关于java - 根据每个字符串的子字符串对 String ArrayList 的一半进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58543291/

相关文章:

string - 为什么我不能像在 trim_right_matches() 中那样在 trim_matches() 中使用 &str?

c++ - 合并排序 - 返回一个新数组而不是将合并后的数组复制到输入数组

java - 我们可以挑出一个警报(例如 "Web Browser XSS Protection Not Enabled")并在 ZAP 代理中重新运行吗

java - 两个具有多个数据源的映射器

Java - 如何匹配包含单引号的正则表达式模式?

python - 如何在父字符串列表中查找子字符串列表对应的索引

javascript - 如何对对象数组进行排序

c# - 在文本文件中读取更多 'intelligently'

algorithm - 众所周知的二进制 (WKB) 到十进制纬度/经度

java - 小程序的 JVM 内存