Como eu classificaria um array 2d em Java? [duplicado]
Nov 19 2020
Então, eu tenho um array 2d em Java que é uma string
String a[][] = new String[3][4]
a[0][0] = "John";
a[0][1] = "Doe";
a[0][2] ="B";
a[0][3] ="999";
a[1][0] ="Bob";
a[1][1] ="Smith";
a[1][2] ="Q";
a[1][3] ="420";
a[2][0] ="Name";
a[2][1] ="Here";
a[2][2] ="T";
a[2][3] ="123";
Como eu classificaria as linhas em ordem alfabética?
Eu tentei Arrays.sort(a), mas apenas gerou erros. E eu sinto que vai ser mais complicado do que isso.
EDITAR: A saída deve ser
Bob Smith Q 420 John Doe B 999 Nome Aqui T 123
Já tenho o código para imprimi-lo funcionando corretamente, só preciso classificá-lo em ordem alfabética por linhas.
Respostas
3 RohanKumar Nov 19 2020 at 07:38
Se você deseja apenas classificar as linhas, acho que pode ser feito assim:
Arrays.sort(a, (o1, o2) -> {
String firstO1Element = o1[0];
String firstO2Element = o2[0];
return firstO1Element.compareTo(firstO2Element);
});
Isso dá a seguinte saída:
Bob Smith Q 420
John Doe B 999
Name Here T 123
Laugslander Nov 19 2020 at 07:33
Você pode resolver este problema com streams:
String[] result = Arrays.stream(a)
.map(inner -> String.join(" ", inner))
.sorted()
.toArray(String[]::new);
LuthermillaMuculadosReis Nov 19 2020 at 07:45
Tente isto
Arrays.sort(a, (b, c) -> b[0] - c[0]);
O que significa um erro “Não é possível encontrar o símbolo” ou “Não é possível resolver o símbolo”?
George Harrison ficou chateado por suas letras de 'Hurdy Gurdy Man' de Donovan não terem sido usadas