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]);