仅对 java 中的字符串数组中的数字元素进行排序?

Sort only Numeric elements from String Array in java?

我只想对字符串数组中的数字元素进行排序。我正在 java 中进行。请帮我解决这个问题。

这是我的问题

对于给定的一组字符,仅选择整数并将它们按降序排列并放入它们的位置,而其他字符的位置保持不变。 变化是位置只能是整数而不是其他字符。

示例输入:-
d,1,4,c,9,6
109,87,911,b,645
77,19,#,.,95
8,99,14,2,5,6,49

示例输出:-
案例 #1:d,9,6,c,4,1
案例#2:911,645,109,b,87
案例 #3:95,77,#,.,19
案例 #4:99,49,14,8,6,5,2

感谢所有观众。请大家帮我解决这个问题 Java

这是我的代码,到目前为止我已经尝试过了。

import java.util.Arrays;
import java.util.Iterator;
import java.util.ArrayList;

class alphaNumeric {

public static void main(String a[]) {

String s1[] = new String[9];
ArrayList l_numList = new ArrayList();
ArrayList l_strList = new ArrayList();

s1[0] = "1000.1";
s1[1] = "100";
s1[2] = "xBC100";
s1[3] = "XBB100";
s1[4] = "TEST";
s1[5] = "AYZ2100";
s1[6] = "99";
s1[7] = "90";
s1[8] = "1000";
System.out.print("Before sorting, numbers are ");
for(int i = 0; i < s1.length; i++)
{
    System.out.print(s1[i]+" ");
}
System.out.println();        



for (int i = 0; i < s1.length; i++) {
    if (isNumber(s1[i])) {
        l_numList.add(s1[i]);
    } else {
        l_strList.add(s1[i]);
    }
}
Object[] l_objArray = (Object[]) l_numList.toArray();
int l_intArray[] = new int[l_objArray.length];
for (int i = 0; i < l_objArray.length; i++) {
    l_intArray[i] = Integer.parseInt((String) l_objArray[i]);
}
Arrays.sort(l_intArray);
for (int i = 0; i < l_intArray.length; i++) {
    System.out.println("after Numsort: " + l_intArray[i]);
}

System.out.print("After sorting, numbers are ");
for(int i = 0; i < l_intArray.length; i++)
{
    System.out.print(l_intArray[i]+" ");
}
Object[] l_strArray = (Object[]) l_strList.toArray();
Arrays.sort(l_strArray);
for (int i = 0; i < l_strArray.length; i++) {
    System.out.println("after Strsort: " + l_strArray[i]);
}
}

static boolean isNumber(String s) {
String validChars = "0123456789";
boolean isNumber = true;

for (int i = 0; i < s.length() && isNumber; i++) {
    char c = s.charAt(i);
    if (validChars.indexOf(c) == -1) {
        isNumber = false;
    } else {
        isNumber = true;
    }
}
return isNumber;
} 
}

我不知道你想做什么,但我会这样做

  • 仅提取整数列表AND创建它们在原始数组中出现的索引列表
  • 使用标准反向排序对该列表进行排序
  • 使用索引 List
  • 将排序后的 List 值放回原始数组

工作示例

public class SortOnlyNumbers {
    public static void main(String[] args) {
        sortOnlyNumbers(new String[] { "d", "1", "4", "c", "9", "6" });
        sortOnlyNumbers(new String[] { "109", "87", "911", "b", "645" });
        sortOnlyNumbers(new String[] { "77", "19", "#", ".", "95" });
        sortOnlyNumbers(new String[] { "8", "99", "14", "2", "5", "6", "49" });
    }

    private static void sortOnlyNumbers(String[] array) {
        List<Integer> indexes = new ArrayList<Integer>();
        List<Integer> numbers = new ArrayList<Integer>();
        for (int i = 0; i < array.length; i++) {
            try {
                numbers.add(Integer.parseInt(array[i]));
                indexes.add(i);
            } catch (NumberFormatException e) {
                // don't care
            }
        }
        Collections.sort(numbers, Collections.reverseOrder());
        for (int i = 0; i < numbers.size(); i++) {
            array[indexes.get(i)] = String.valueOf(numbers.get(i));
        }
        System.out.println(Arrays.toString(array));
    }
}

输出

[d, 9, 6, c, 4, 1]
[911, 645, 109, b, 87]
[95, 77, #, ., 19]
[99, 49, 14, 8, 6, 5, 2]