目次
1. 検索アルゴリズム
バイナリ アルゴリズム
2. 並べ替えアルゴリズム
バブル ソート
選択ソート
挿入ソート
クイック ソート
ホームページ Java &#&チュートリアル Java プログラミングで検索アルゴリズムと並べ替えアルゴリズムをすばやくマスターする方法

Java プログラミングで検索アルゴリズムと並べ替えアルゴリズムをすばやくマスターする方法

Apr 25, 2023 pm 05:13 PM
java

1. 検索アルゴリズム

バイナリ アルゴリズム

バイナリ サーチ (Binary Search) は、ハーフサーチとも呼ばれ、効率的な検索アルゴリズムです。その基本的な考え方は、順序付けされた配列 (またはセット) を 2 つに分割することです。現在の中央の要素がターゲット要素と等しい場合、検索は成功します。現在の中央の要素がターゲット要素より大きい場合、左半分が検索されます。 ; 現在の中央の要素がターゲット要素より小さい場合、右半分を検索します。目的の要素が見つかるか、検索範囲が空になって検索が失敗するまで、上記の手順を繰り返します。

次は、Java で実装されたバイナリ アルゴリズムです。

public static int binarySearch(int[] arr, int target) {
    if (arr == null || arr.length == 0) {
        return -1;
    }
    int left = 0;
    int right = arr.length - 1;
    while (left <= right) {
        int mid = left + (right - left) / 2;
        if (arr[mid] == target) {
            return mid;
        } else if (arr[mid] > target) {
            right = mid - 1;
        } else {
            left = mid + 1;
        }
    }
    return -1;
}
ログイン後にコピー

上記のメソッドは、順序付けられた整数配列のセットとターゲット値をパラメーターとして使用し、ターゲット値のインデックスを返します。 array; if 対象の値が配列内に存在しない場合は、-1 が返されます。

アルゴリズムの中核は while ループで、左右が特定の条件を満たしたときに繰り返し実行されます。

  • mid が target と等しい場合、mid が返されます。そしてアルゴリズムは終了します ;

  • mid がターゲットより大きい場合は、左側で検索を続けます、つまり、右側を Mid - 1 に設定します;

  • mid がターゲットより小さい場合は、右側で検索を続けます。つまり、左側を Mid 1 に設定します。

ループを実行するたびに、mid = left (right - left) / 2 を使用して中央要素のインデックスを計算します。 (left right) / 2 の形式ではなく、left right の形式を使用する必要があることに注意してください。そうしないと、整数オーバーフローの問題が発生する可能性があります。

2. 並べ替えアルゴリズム

Java では、並べ替えアルゴリズムは Comparable または Comparator インターフェイスを実装することによって実装されます。以下に、一般的に使用されるいくつかの並べ替えアルゴリズムとその実装方法を示します。

バブル ソート

バブル ソートは、単純な並べ替えアルゴリズムです。アイデアは、2 つの隣接する要素を常に比較し、順序が間違っている場合は位置を交換することです。この過程は水の泡が立ち上るのに似ているので、バブルソーティングと呼ばれます。

public static void bubbleSort(int[] arr) {
    int temp;
    for (int i = 0; i < arr.length - 1; i++) {
        for (int j = 0; j < arr.length - i - 1; j++) {
            if (arr[j] > arr[j + 1]) {
                //交换位置
                temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}
ログイン後にコピー

選択ソート

選択ソートの考え方は、未ソートの要素から最小の要素を選択し、ソートの最後に置くことです。最小の要素が見つかるたびに、その位置が現在ソートされていない最初の要素と交換されます。

public static void selectionSort(int[] arr) {
    int minIndex;
    for (int i = 0; i < arr.length - 1; i++) {
        minIndex = i;
        for (int j = i + 1; j < arr.length; j++) {
            if (arr[j] < arr[minIndex]) {
                minIndex = j;
            }
        }
        //交换位置
        int temp = arr[i];
        arr[i] = arr[minIndex];
        arr[minIndex] = temp;
    }
}
ログイン後にコピー

挿入ソート

挿入ソートの考え方は、ソートされていない要素をソートされた適切な位置に挿入することです。未ソートの要素から要素を選択し、ソート済みの要素を後ろから前に移動します。ソート済みの要素より小さい場合は、1 つ後ろに移動して比較を続け、未ソートの要素より小さい位置が見つかるまで、その要素を次の位置に挿入します。この場所。

public 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;
    }
}
ログイン後にコピー

クイック ソート

クイック ソートは、分割統治の考え方に基づいた並べ替えアルゴリズムです。ピボット ポイントを選択し、配列をピボット ポイント以下とピボット ポイントより大きい 2 つの部分配列に分割し、2 つの部分配列を再帰的に並べ替えます。

rree

以上がJava プログラミングで検索アルゴリズムと並べ替えアルゴリズムをすばやくマスターする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Javaの完全数 Javaの完全数 Aug 30, 2024 pm 04:28 PM

Java における完全数のガイド。ここでは、定義、Java で完全数を確認する方法、コード実装の例について説明します。

ジャワのウェカ ジャワのウェカ Aug 30, 2024 pm 04:28 PM

Java の Weka へのガイド。ここでは、weka java の概要、使い方、プラットフォームの種類、利点について例を交えて説明します。

Javaのスミス番号 Javaのスミス番号 Aug 30, 2024 pm 04:28 PM

Java のスミス番号のガイド。ここでは定義、Java でスミス番号を確認する方法について説明します。コード実装の例。

Java Springのインタビューの質問 Java Springのインタビューの質問 Aug 30, 2024 pm 04:29 PM

この記事では、Java Spring の面接で最もよく聞かれる質問とその詳細な回答をまとめました。面接を突破できるように。

Java 8 Stream Foreachから休憩または戻ってきますか? Java 8 Stream Foreachから休憩または戻ってきますか? Feb 07, 2025 pm 12:09 PM

Java 8は、Stream APIを導入し、データ収集を処理する強力で表現力のある方法を提供します。ただし、ストリームを使用する際の一般的な質問は次のとおりです。 従来のループにより、早期の中断やリターンが可能になりますが、StreamのForeachメソッドはこの方法を直接サポートしていません。この記事では、理由を説明し、ストリーム処理システムに早期終了を実装するための代替方法を調査します。 さらに読み取り:JavaストリームAPIの改善 ストリームを理解してください Foreachメソッドは、ストリーム内の各要素で1つの操作を実行する端末操作です。その設計意図はです

Java での日付までのタイムスタンプ Java での日付までのタイムスタンプ Aug 30, 2024 pm 04:28 PM

Java での日付までのタイムスタンプに関するガイド。ここでは、Java でタイムスタンプを日付に変換する方法とその概要について、例とともに説明します。

カプセルの量を見つけるためのJavaプログラム カプセルの量を見つけるためのJavaプログラム Feb 07, 2025 am 11:37 AM

カプセルは3次元の幾何学的図形で、両端にシリンダーと半球で構成されています。カプセルの体積は、シリンダーの体積と両端に半球の体積を追加することで計算できます。このチュートリアルでは、さまざまな方法を使用して、Javaの特定のカプセルの体積を計算する方法について説明します。 カプセルボリュームフォーミュラ カプセルボリュームの式は次のとおりです。 カプセル体積=円筒形の体積2つの半球体積 で、 R:半球の半径。 H:シリンダーの高さ(半球を除く)。 例1 入力 RADIUS = 5ユニット 高さ= 10単位 出力 ボリューム= 1570.8立方ユニット 説明する 式を使用してボリュームを計算します。 ボリューム=π×R2×H(4

Spring Tool Suiteで最初のSpring Bootアプリケーションを実行するにはどうすればよいですか? Spring Tool Suiteで最初のSpring Bootアプリケーションを実行するにはどうすればよいですか? Feb 07, 2025 pm 12:11 PM

Spring Bootは、Java開発に革命をもたらす堅牢でスケーラブルな、生産対応のJavaアプリケーションの作成を簡素化します。 スプリングエコシステムに固有の「構成に関する慣習」アプローチは、手動のセットアップを最小化します。

See all articles