ホームページ > Java > &#&チュートリアル > Javaで挿入ソートアルゴリズムを実装するにはどうすればよいですか?

Javaで挿入ソートアルゴリズムを実装するにはどうすればよいですか?

WBOY
リリース: 2023-04-23 12:07:20
転載
1678 人が閲覧しました

    1. 基本的な考え方

    挿入ソート (Insertion-Sort) のアルゴリズムの説明は、シンプルで直感的なソート アルゴリズムです。これは、順序付けされたシーケンスを構築することで機能し、並べ替えられていないデータの場合は、並べ替えられたシーケンス内で後ろから前にスキャンし、対応する位置を見つけて挿入します。

    2. アルゴリズム分析

    1. アルゴリズムの説明

    一般的に、挿入ソートは配列に対して in-place を使用して実装されます。具体的なアルゴリズムは次のように説明されます:

    • 最初の要素から開始して、要素はソートされていると見なされます;

    • 取り出し次の要素、並べ替えられた要素シーケンスを後ろから前にスキャンします;

    • 要素 (並べ替えられた) が新しい要素より大きい場合、要素を次の位置に移動します;

    • 並べ替えられた要素が新しい要素以下になる位置が見つかるまで手順 3 を繰り返します。

    • その位置に新しい要素を挿入します。位置;

    • 手順 2 ~ 5 を繰り返します。

    #2. プロセス分析

    (1) 最初の要素 (1) を並べ替え済みとしてマークします。

    Javaで挿入ソートアルゴリズムを実装するにはどうすればよいですか?

    (2)、ソートされていない最初の要素 (28) を抽出します。

    Javaで挿入ソートアルゴリズムを実装するにはどうすればよいですか?

    (3) 抽出した要素が挿入されている場所を見つけ、ソートされた要素 1 と比較します。

    Javaで挿入ソートアルゴリズムを実装するにはどうすればよいですか?

    (4)、1 > 28 が true (False) でない場合は、既存の位置に要素を挿入します。

    Javaで挿入ソートアルゴリズムを実装するにはどうすればよいですか?

    (5). 抽出した要素が挿入されている場所を見つけ、ソートされた要素と比較します28。

    Javaで挿入ソートアルゴリズムを実装するにはどうすればよいですか?

    (6), 28 > 3 true (True) の場合、現在ソートされている要素 ({val1}) が 1 スペース右に移動されます。

    Javaで挿入ソートアルゴリズムを実装するにはどうすればよいですか?

    (7) 抽出した要素が挿入されている場所を見つけ、ソートされた要素 1 と比較します。

    Javaで挿入ソートアルゴリズムを実装するにはどうすればよいですか?

    (8)、1 > 3 が true (False) でない場合は、既存の位置に要素を挿入します。

    Javaで挿入ソートアルゴリズムを実装するにはどうすればよいですか?

    (9) など

    Javaで挿入ソートアルゴリズムを実装するにはどうすればよいですか?

    #3. アルゴリズムの実装

    package com.algorithm.tenSortingAlgorithm;
    
    import java.util.Arrays;
    
    public class InsertionSort {
        private static void insertionSort(int[] arr) {
            int preIndex, current;
            for (int i = 1; i < arr.length; i++) {
                preIndex = i - 1;
                current = arr[i];
                while (preIndex >= 0 && arr[preIndex] > current) {
                    arr[preIndex + 1] = arr[preIndex];
                    preIndex--;
                }
                arr[preIndex + 1] = current;
            }
        }
    
        public static void main(String[] args) {
            int[] arr = {1,28,3,21,11,7,6,18};
            insertionSort(arr);
            System.out.println(Arrays.toString(arr));
        }
    }
    ログイン後にコピー

    以上がJavaで挿入ソートアルゴリズムを実装するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

    関連ラベル:
    ソース:yisu.com
    このウェブサイトの声明
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
    人気のチュートリアル
    詳細>
    最新のダウンロード
    詳細>
    ウェブエフェクト
    公式サイト
    サイト素材
    フロントエンドテンプレート