Rumah >Java >javaTutorial >Bagaimana untuk Mengisih Tatasusunan Rentetan 2D mengikut Lajur Tertentu di Jawa?

Bagaimana untuk Mengisih Tatasusunan Rentetan 2D mengikut Lajur Tertentu di Jawa?

Linda Hamilton
Linda Hamiltonasal
2024-11-04 01:33:03380semak imbas

How to Sort a 2D String Array by a Specific Column in Java?

Mengisih Tatasusunan Rentetan 2D mengikut Lajur Tertentu

Di Java, kita boleh menghadapi situasi di mana kita perlu menyusun data yang disimpan dalam dua tatasusunan -dimensi (2D). Untuk mencapai pengisihan ini dengan berkesan, kami boleh menggunakan kaedah Arrays.sort() bersama-sama dengan pembanding tersuai.

Pertimbangkan contoh berikut: Kami mempunyai tatasusunan rentetan 2D di mana lajur pertama mewakili cap masa dan yang kedua lajur mengandungi mesej. Matlamat kami adalah untuk mengisih tatasusunan berdasarkan cap masa dalam tertib menaik.

Untuk mencapai ini, kami boleh menentukan kelas yang melaksanakan antara muka Pembanding. Kelas ini akan menyediakan logik untuk membandingkan elemen dalam tatasusunan:

<code class="java">class TimestampComparator implements Comparator<String[]> {
    @Override
    public int compare(String[] entry1, String[] entry2) {
        return entry1[0].compareTo(entry2[0]);
    }
}</code>

Dalam pembanding ini, kami mengekstrak nilai cap masa daripada setiap entri dalam tatasusunan dan membandingkannya menggunakan kaedah String.compareTo().

Dengan adanya pembanding kami, kami kini boleh meneruskan pengisihan:

<code class="java">Arrays.sort(data, new TimestampComparator());</code>

Di sini, data mewakili tatasusunan 2D asal.

Selepas mengisih, data akan disusun berdasarkan cap masa dalam lajur pertama. Output yang terhasil ialah:

2009.07.25 19:54 Message R
2009.07.25 20:01 Message F
2009.07.25 20:17 Message G
2009.07.25 20:24 Message A
2009.07.25 20:25 Message B
2009.07.25 20:30 Message D
2009.07.25 21:08 Message E

Atas ialah kandungan terperinci Bagaimana untuk Mengisih Tatasusunan Rentetan 2D mengikut Lajur Tertentu di Jawa?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn