Rumah >Java >javaTutorial >Bagaimana untuk menulis kod untuk melaksanakan jenis gelembung dalam Java

Bagaimana untuk menulis kod untuk melaksanakan jenis gelembung dalam Java

WBOY
WBOYke hadapan
2023-05-03 16:43:06734semak imbas

Bagaimana untuk menulis kod untuk melaksanakan jenis gelembung dalam Java


Prinsip isihan gelembung

  1. Bandingkan dua elemen bersebelahan. Jika yang pertama lebih besar daripada yang kedua, tukar kedudukan mereka (dalam tertib menaik, begitu juga sebaliknya dalam tertib menurun).

  2. Bandingkan setiap pasangan elemen bersebelahan dalam urutan dari awal hingga akhir senarai. Dengan cara ini, elemen dengan nilai terbesar "gelembung" ke penghujung senarai melalui pertukaran, melengkapkan pusingan pertama "gelembung".

  3. Ulang langkah sebelumnya dan teruskan membandingkan elemen bersebelahan dari permulaan senarai. Elemen yang telah "berbuih" tidak perlu dibandingkan (anda boleh membandingkannya sehingga akhir. Elemen yang telah "berbuih" ke belakang tidak perlu ditukar walaupun ia dibandingkan. Tidak membandingkan boleh mengurangkan langkah).

  4. Teruskan membuat perbandingan bermula dari senarai, dan satu elemen akan "bergelembung" dengan jayanya dalam setiap pusingan perbandingan. Bilangan elemen yang perlu dibandingkan dalam setiap pusingan akan berkurangan sehingga hanya tinggal satu elemen sahaja yang tidak "bergelembung" (tiada pasangan elemen yang perlu dibandingkan), kemudian penyusunan senarai selesai.

Proses isihan buih

Ambil tatasusunan satu dimensi ini sebagai contoh:

int[] array = new int[]{55,33,22,66,11};
Pusingan pertama buih
  1. Rajah ① ialah carta lajur bagi susunan permulaan data dalam pusingan pertama "gelembung". ditukar, jika tidak, tiada pertukaran akan berlaku."

  2. tatasusunan[0]=55 >

  3. tatasusunan[1]=55 > tatasusunan[2]=22, jika syarat dipenuhi, tukarkan susunan kedudukan elemen, seperti yang ditunjukkan dalam Rajah ③;

    tatasusunan[2] =55
  4. tatasusunan[3]=66 > tatasusunan[ 4]=11, jika syarat dipenuhi, susunan kedudukan elemen ditukar, seperti yang ditunjukkan dalam Rajah ④;

    Pusingan pertama demonstrasi "gelembung" adalah seperti yang ditunjukkan dalam rajah:

  5. Pusingan kedua menggelegak

Rajah ④ menunjukkan carta lajur pesanan permulaan data dalam pusingan kedua "gelembung";
Bagaimana untuk menulis kod untuk melaksanakan jenis gelembung dalam Java

tatasusunan[0]33 > susunan kedudukan unsur-unsur, seperti yang ditunjukkan dalam Rajah ⑤; elemen tidak ditukar, seperti yang ditunjukkan dalam Rajah ⑤;
  1. tatasusunan[2]55 > ditukar, seperti yang ditunjukkan dalam Rajah ⑥;

  2. Pusingan kedua demonstrasi "gelembung" adalah seperti yang ditunjukkan dalam rajah:

  3. Pusingan ketiga daripada menggelegak

  4. Rajah ⑥ menunjukkan carta lajur jujukan permulaan data dalam pusingan ketiga "buih"

tatasusunan[0] =22 tatasusunan[2]=11, jika syarat dipenuhi, tukarkan susunan kedudukan elemen, seperti yang ditunjukkan dalam Rajah ⑦; demonstrasi adalah seperti berikut Seperti yang ditunjukkan dalam rajah:
Bagaimana untuk menulis kod untuk melaksanakan jenis gelembung dalam Java

Pusingan keempat menggelegak
  1. Rajah ⑦ menunjukkan lajur tertib permulaan data dalam pusingan keempat rajah bentuk "gelembung";

  2. tatasusunan[0]=22 > " dan "11", seperti yang ditunjukkan dalam Rajah ⑧ ;

  3. Pusingan keempat demonstrasi "gelembung" ditunjukkan dalam rajah:

Pada ketika ini, proses pengisihan buih tatasusunan selesai La!
Bagaimana untuk menulis kod untuk melaksanakan jenis gelembung dalam Java

Pelaksanaan kod khusus
Kelas BubbleSort:
    public class BubbleSort {
        public static void sort(int array[]) {
            //i表示第几轮“冒泡”,j 表示“走访”到的元素索引。
            // 每一轮“冒泡”中,j 需要从列表开头“走访”到 array.length - 1 的位置。
            for (int i = 0; i < array.length - 1; i++) {
                for (int j = 0; j < array.length - 1 - i; j++) {
                    if (array[j] > array[j + 1]) {
                        int temp = array[j];
                        array[j] = array[j + 1];
                        array[j + 1] = temp;
                    }
                }
            }
        }}
  1. TestMain class

    import java.util.Arrays;public class TestMain {
        public static void main(String[] args) {
            int[] array = new int[]{55, 33, 22, 66, 11};
            //输出排序前的array数组
            System.out.print("排序前:");
            System.out.println(Arrays.toString(array));
            //调用BubbleSort类中的sort方法对array数组进行排序
            BubbleSort.sort(array);
            //输出冒泡排序后的array数组
            System.out.print("排序后:");
            System.out.println(Arrays.toString(array));
        }}

    Keputusan yang dijalankan adalah seperti berikut:
  2. rreee

Atas ialah kandungan terperinci Bagaimana untuk menulis kod untuk melaksanakan jenis gelembung dalam Java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:yisu.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam