3 回答

TA貢獻1806條經驗 獲得超8個贊
假設[7,11,10,6,9]是輸入,我們可以嘗試轉換為整數列表,然后對該列表進行排序:
String input = "[7,11,10,6,9]";
input = input.replaceAll("\\[(.*)\\]", "$1");
String[] vals = input.split(",");
List<Integer> output = Arrays.stream(vals)
.map(v -> Integer.parseInt(v))
.collect(Collectors.toList());
Collections.sort(output);
System.out.println(Arrays.toString(output.toArray()));
這打?。?/p>
[6, 7, 9, 10, 11]

TA貢獻1828條經驗 獲得超3個贊
您可以replace()一次完成這些行并使用正則表達式更干凈地拆分:
parts = line.split("[\\[\\], ]+");
并使用 cameron1024 在他的回答中演示的 Iterable 技術。我認為Iterable對于此用例,using 是比 using 更好的選擇Streams,因為輸入大小非常小并且Streams必須花費更多時間來啟動。
整個事情看起來像:
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
String[] parts;
List<String> linhas = new ArrayList<>();
for (int i = 0; i < 3; i++) {
String line = br.readLine();
parts = line.split("[\\[\\] ,]+");
}
int ints[] = new int[parts.length];
for(int i = 0; i < parts.length; i++){
ints[i] = Integer.parseInt(parts[i]);
}
Arrays.sort(ints);

TA貢獻1813條經驗 獲得超2個贊
一旦你有了,parts你必須把它轉換String[]成一個int[]. 為此,首先為要輸入的結果創建一個 int[]。它必須與您的大小相同String[]:
int[] ints = new int[parts.length];
然后,遍歷String[]并在 中填充值int[]:
for (int i = 0; i < parts.length; i++) {
ints[i] = Integer.parseInt(parts[i]); // converts a string containing an integer into its int value
}
最后,要對每一行進行排序,只需調用 即可對Arrays.sort(ints);整數數組進行排序。
獎金:
這可以使用 Java 8 Streams 在一行中更干凈地實現,如下所示:
List<Integer> sortedInts = Arrays.stream(parts).map(Integer::parseInt).sorted().collect(Collectors.toList());
添加回答
舉報