Menggunakan Pembanding untuk Isih Tersuai
Apabila melaksanakan mekanisme isihan, adalah penting untuk menentukan susunan isihan tersuai untuk memenuhi keperluan khusus. Dalam konteks ini, Java menyediakan Comparator untuk memudahkan operasi sedemikian.
Dalam contoh anda, anda menyasarkan untuk mengisih senarai kereta mengikut warnanya, tetapi tidak mengikut susunan abjad. Anda inginkan pesanan tersuai di mana "Merah" didahulukan, diikuti dengan "Biru" dan seterusnya.
Untuk mencapainya, langkah berikut boleh dilaksanakan:
1. Tentukan Enum untuk Warna Kereta:
Buat enum bernama PaintColors untuk mewakili warna kereta yang tersedia. Pendekatan ini memastikan bahawa susunan semula jadi enum sepadan dengan susunan isihan yang anda inginkan.
public enum PaintColors { SILVER, BLUE, MAGENTA, RED }
2. Ubah Suai Kelas Kereta:
Daripada menggunakan tali untuk warna, tukar Kereta untuk menggunakan enum PaintColors.
public class CarSort { private String name; private PaintColors color; ... }
3. Laksanakan Pembanding untuk Isih Warna:
Tentukan kelas pembanding yang dipanggil ColorComparator untuk membandingkan kereta berdasarkan warnanya.
static class ColorComparator implements Comparator<CarSort> { public int compare(CarSort c1, CarSort c2) { return c1.getColor().compareTo(c2.getColor()); } }
4. Sesuaikan Isih dalam Kaedah Utama:
Dalam kaedah utama, ubah suai kod untuk menggunakan Collections.sort dengan ColorComparator:
Collections.sort(carList, new ColorComparator());
Dengan melaksanakan langkah-langkah ini, anda boleh mewujudkan susunan isihan tersuai untuk senarai kereta anda, membolehkan anda mengutamakan warna tertentu mengikut keperluan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menyisih Senarai Kereta mengikut Susunan Warna Tersuai Menggunakan Pembanding Java?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!