Rumah Java javaTutorial Memahami Algoritma Isih Sisipan (dengan Contoh dalam Java)

Memahami Algoritma Isih Sisipan (dengan Contoh dalam Java)

Jan 18, 2025 am 02:16 AM

Isihan sisipan ialah algoritma isihan berulang. Ia membina subarray yang diisih satu elemen pada satu masa dengan memasukkan setiap elemen yang tidak diisih ke dalam kedudukan yang betul dalam subarray yang diisih. Fikirkan untuk mengisih tangan bermain kad – anda mulakan dengan satu kad yang diisih, kemudian masukkan setiap kad berikutnya ke tempat yang sepatutnya di antara kad yang telah diisih.

Cara Isih Sisipan Berfungsi

Mari kita gambarkan dengan tatasusunan contoh yang ingin kita susun dalam tertib menaik:

Understanding Insertion Sort Algorithm (with Examples in Java)

Lelaran Pertama:

Kami menganggap elemen pertama sudah diisih. Algoritma bermula dengan elemen kedua.

Understanding Insertion Sort Algorithm (with Examples in Java)

Membandingkan 2 dengan 8, sejak 2 < 8, kita alihkan 8 ke kanan dan masukkan 2 ke kiri.

Understanding Insertion Sort Algorithm (with Examples in Java)

Lelaran Kedua:

Kami membandingkan 6 dengan subarray yang diisih (2, 8). 6 < 8, jadi 8 anjakan ke kanan. Kemudian, sejak 6 > 2, 6 diletakkan di sebelah kanan 2.

Understanding Insertion Sort Algorithm (with Examples in Java)

Proses ini berterusan sehingga keseluruhan tatasusunan diisih.

Understanding Insertion Sort Algorithm (with Examples in Java) Understanding Insertion Sort Algorithm (with Examples in Java) Understanding Insertion Sort Algorithm (with Examples in Java)

Pelaksanaan dalam Java

import java.util.Arrays;

public class InsertionSortTest {
    public static void main(String[] args) {
        int[] arr = {8, 2, 6, 4, 9, 1};
        System.out.println("Unsorted array: " + Arrays.toString(arr));
        insertionSort(arr);
        System.out.println("Sorted array: " + Arrays.toString(arr));
    }

    public static void insertionSort(int[] arr) {
        for (int i = 1; i &lt; arr.length; i++) {
            int key = arr[i];
            int j = i - 1;
            while (j &gt;= 0 &amp;&amp; arr[j] &gt; key) {
                arr[j + 1] = arr[j];
                j--;
            }
            arr[j + 1] = key;
        }
    }
}
Salin selepas log masuk

Kod berulang, mengambil setiap elemen sebagai key. Ia kemudian membandingkan key dengan elemen dalam bahagian yang diisih, mengalihkan elemen yang lebih besar ke kanan sehingga kedudukan yang betul untuk key ditemui.

Sebagai contoh, dalam lelaran kedua (i=2):

Understanding Insertion Sort Algorithm (with Examples in Java)

key ialah 6. Gelung while menganjak elemen sehingga kedudukan yang betul ditemui:

Understanding Insertion Sort Algorithm (with Examples in Java) Understanding Insertion Sort Algorithm (with Examples in Java)

Akhir sekali, 6 dimasukkan:

Understanding Insertion Sort Algorithm (with Examples in Java)

Output:

Tatasusunan tidak diisih: [8, 2, 6, 4, 9, 1] Tatasusunan diisih: [1, 2, 4, 6, 8, 9]

Analisis Kerumitan

  • Kerumitan Masa:
    • Kes Terbaik (O(n)): Tatasusunan sudah diisih.
    • Kes Purata (O(n²)): Elemen yang disusun secara rawak.
    • Kes Terburuk (O(n²)): Tatasusunan diisih terbalik.
  • Kerumitan Angkasa: O(1) (Algoritma di tempat)

Kesimpulan

Kerumitan masa kuadratik jenis sisipan menjadikannya tidak cekap untuk set data yang besar. Walau bagaimanapun, ia adalah algoritma yang mudah dan berfungsi dengan baik pada set data kecil atau data yang hampir diisih.

Atas ialah kandungan terperinci Memahami Algoritma Isih Sisipan (dengan Contoh dalam Java). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
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

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Rangka Kerja 4 JavaScript teratas pada tahun 2025: React, Angular, Vue, Svelte Rangka Kerja 4 JavaScript teratas pada tahun 2025: React, Angular, Vue, Svelte Mar 07, 2025 pm 06:09 PM

Rangka Kerja 4 JavaScript teratas pada tahun 2025: React, Angular, Vue, Svelte

Bagaimanakah mekanisme kelas muatan Java berfungsi, termasuk kelas yang berbeza dan model delegasi mereka? Bagaimanakah mekanisme kelas muatan Java berfungsi, termasuk kelas yang berbeza dan model delegasi mereka? Mar 17, 2025 pm 05:35 PM

Bagaimanakah mekanisme kelas muatan Java berfungsi, termasuk kelas yang berbeza dan model delegasi mereka?

Bagaimanakah saya menggunakan Maven atau Gradle untuk Pengurusan Projek Java Lanjutan, Membina Automasi, dan Resolusi Ketergantungan? Bagaimanakah saya menggunakan Maven atau Gradle untuk Pengurusan Projek Java Lanjutan, Membina Automasi, dan Resolusi Ketergantungan? Mar 17, 2025 pm 05:46 PM

Bagaimanakah saya menggunakan Maven atau Gradle untuk Pengurusan Projek Java Lanjutan, Membina Automasi, dan Resolusi Ketergantungan?

Node.js 20: Peningkatan Prestasi Utama dan Ciri -ciri Baru Node.js 20: Peningkatan Prestasi Utama dan Ciri -ciri Baru Mar 07, 2025 pm 06:12 PM

Node.js 20: Peningkatan Prestasi Utama dan Ciri -ciri Baru

Iceberg: Masa Depan Jadual Data Tasik Iceberg: Masa Depan Jadual Data Tasik Mar 07, 2025 pm 06:31 PM

Iceberg: Masa Depan Jadual Data Tasik

Bagaimanakah saya melaksanakan caching pelbagai peringkat dalam aplikasi java menggunakan perpustakaan seperti kafein atau cache jambu? Bagaimanakah saya melaksanakan caching pelbagai peringkat dalam aplikasi java menggunakan perpustakaan seperti kafein atau cache jambu? Mar 17, 2025 pm 05:44 PM

Bagaimanakah saya melaksanakan caching pelbagai peringkat dalam aplikasi java menggunakan perpustakaan seperti kafein atau cache jambu?

Spring Boot Snakeyaml 2.0 CVE-2022-1471 Isu Tetap Spring Boot Snakeyaml 2.0 CVE-2022-1471 Isu Tetap Mar 07, 2025 pm 05:52 PM

Spring Boot Snakeyaml 2.0 CVE-2022-1471 Isu Tetap

Cara berkongsi data antara langkah -langkah dalam timun Cara berkongsi data antara langkah -langkah dalam timun Mar 07, 2025 pm 05:55 PM

Cara berkongsi data antara langkah -langkah dalam timun

See all articles