Rumah >Java >javaTutorial >Bagaimana untuk Mengisih Tatasusunan Rentetan 2D mengikut Lajur Tertentu di Jawa?
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!