Rumah >Java >javaTutorial >Bagaimana untuk Mengisih Tatasusunan 2D mengikut Lajur Pertamanya di Jawa?
Isih Tatasusunan 2D mengikut Lajur Pertama Menggunakan Tatasusunan Java.sort
Di Jawa, menyusun tatasusunan 2D berdasarkan nilai lajur pertama boleh dicapai menggunakan kaedah Arrays.sort terbeban yang mengambil Comparator sebagai hujah kedua. Pembanding ini membolehkan anda menentukan logik perbandingan tersuai untuk mengisih elemen tatasusunan.
Untuk mengisih tatasusunan 2D menggunakan nilai lajur pertama, anda boleh mengikuti langkah berikut:
Buat pelaksanaan Pembanding yang membandingkan unsur-unsur pertama subarrays. Ini boleh dilakukan menggunakan kaedah Double.compare untuk membandingkan nilai berganda:
Comparator<double[]> comparator = (a, b) -> Double.compare(a[0], b[0]);
Panggil kaedah Arrays.sort dengan tatasusunan dan Comparator sebagai argumen:
Arrays.sort(array, comparator);
Sebagai alternatif, jika anda menggunakan Java 8 atau lebih tinggi, anda boleh menggunakan fungsi lambda untuk memudahkan Pembanding:
Arrays.sort(array, Comparator.comparingDouble(a -> a[0]));
Contoh:
Pertimbangkan tatasusunan 2D myArr berikut :
double[][] myArr = { {1, 5}, {13, 1.55}, {12, 100.6}, {12.1, .85} };
Selepas mengisih myArr menggunakan pendekatan yang diterangkan di atas, ia akan diisih berdasarkan nilai lajur pertama:
1 5 12 100.6 12.1 .85 13 1.55
Atas ialah kandungan terperinci Bagaimana untuk Mengisih Tatasusunan 2D mengikut Lajur Pertamanya di Jawa?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!