検索
ホームページJava&#&チュートリアルJava クラシック アルゴリズム バブル ソート コード共有

原題: Java の古典的なアルゴリズム: バブルソート (バブルソート)

バブルソートとは何ですか?

バブル ソートは、順序に基づいて要素をペアごとに比較する単純な並べ替えアルゴリズムです。順序が大から小の場合、2 つの要素が相互に比較されると、大きい方が最初にランク付けされ、そうでない場合は、大きい方が後にランク付けされます。バブル選別は大から小への選別と小から大への選別に分かれます。

原則: 2 つの隣接する要素を比較し、値が大きい方の要素を右端に入れ替えます。

アイデア: 2 つの隣接する数値を順番に比較し、小数を前に、大きい数値を後ろに置きます。つまり、最初のパスでは、まず 1 番目と 2 番目の数値を比較し、小数点を前に、大きな数値を後ろに置きます。次に、2 番目の数値と 3 番目の数値を比較し、小数を前に、大きな数値を後ろに置きます。最後の 2 つの数値を比較するまで同様に、小数を前に、大きな数値を後ろに置きます。すべての並べ替えが完了するまで、最初の手順を繰り返します。

例: 配列をソートするには: int[] arr={6,3,8,2,9,1};

最初のソート:

最初のソート: 6 363より大きい、交換位置: 3 6 8 2 9 1

2番目の並べ替え: 6 8 比較: 6は、位置を交換せずに8より小さい: 3 6 8 2 9 1

3番目の並べ替え: 82 比較してください 82より大きい、位置を入れ替える: 3 6 2 8 9 1

89より小さい より大きい1 、位置の交換: 3 6 2 8 1 9 最初のトリップで合計 5

の比較が行われ、ソート結果:

3 6 2 8 1 9

------------------------------------------------- --------------------

2回目の並べ替え:

1回目の並べ替え: 363 の比較は6より小さい、位置を交換せず: 3 6 2 8 1 9

2番目の並べ替え: 62の比較、 6 より大きい2、位置交換: 3 2 6 8 1 9

3番目の並べ替え: 68の比較、6より大きい8、位置の交換なし: 3 2 6 8 1 9

4番目の並べ替え: 81を比較すると、81より大きい、位置を交換します: 3 2 6 1 8 9

2 回目の旅行では、合計 4 の比較が実行され、ソート結果は次のとおりです: 3 2 6 1 8 9

--- ---------------------------------------------------- ------- --------

3回目の並べ替え:

1回目の並べ替え: 32を比較すると、3より大きい2、位置を交換: 2 3 6 1 8 9

2番目の並べ替え: 36を比較すると、3の方が少ない6より 、位置を交換しないでください: 2 3 6 1 8 9

3番目の並べ替え: 61を比較すると、61より大きく、位置を入れ替えます: 2 3 1 6 8 9

2つ目合計 3 の比較が行われ、 並べ替え結果: 2 3 1 6 8 9

---------------------- -------------------------------------------------- --

4 回目の並べ替え:

最初の並べ替え: 23 を比較すると、 2 3 より小さく、位置は交換されません: 2 3 1 6 8 9

2 番目の並べ替え: 31 を比較すると、31 より大きいため、位置を交換します。 2 1 3 6 8 9 2回目の旅行は合計で

2

の比較、の並べ替え結果: 2 1 3 6 8 9----------------- ------------ -------------------------------------- --

5回目の並べ替え:

最初の並べ替え: 2

1を比較すると、21より大きく、位置を入れ替えます: 1 2 3 6 8 9 2 回目の旅行 合計

1

の比較が行われ、 並べ替え結果: 1 2 3 6 8 9-------------- ------------ -------------------------------------- -------------

最終結果:

1 2 3 6 8 9

------ ------------------------ ------------------------ --------

次のことがわかります:

N

個の数値を並べ替える必要があり、合計 N-1 の並べ替え、各 i の並べ替えの数時間は(N-i)回なので、二重ループステートメントを使用できます。外側の層はループの回数を制御し、内側の層はそれぞれの回数を制御します。つまり、


for(int i=1;i<arr.length><p><br></p>
<p style="margin-left: 60px;"><span style="color: #003300; font-size: 14px;">バブルソートの利点: ソートが実行されるたびに、より大きな値が見つかるため、比較が 1 つ少なくなります。上の例のように、最初の比較の後、最後の数値が最大の数値である必要があります。2 回目の並べ替えでは、最後の数値を除く他の数値を比較するだけでよく、数値はランク付けされます。 3 番目の比較では、最後の 2 つの数値を除く他の数値のみを比較する必要があります。つまり、比較を行わないと、毎回の旅行ごとに比較が 1 つ減ります。ある程度のアルゴリズムの量。 </span></p>
<p style="margin-left: 60px;"><span style="color: #003300; font-size: 14px;">時間の複雑さの観点から: </span></p>
<p style="margin-left: 60px;"><span style="color: #003300; font-size: 14px;"> 1. データが整っていれば、並べ替えを完了するのに 1 回の移動だけで済みます。必要な比較数 <span style="line-height: 1.5;"> とレコード移動数 </span> は両方とも最小値に達します: C<sub>min</sub>=n-1; したがって、バブルソートの最適な時間計算量は O<sub> です。 (n)。 </sub><sub></sub></span></p>
<p style="margin-left: 60px;"> <span style="color: #003300; font-size: 14px;"><sub>2. 残念ながらデータが逆順の場合は、n-1</sub><span style="line-height: 1.5;">の並べ替えを実行する必要があります。各ソート パスには n-i</span> 比較<span style="line-height: 1.5;">(1≤i≤n-1)</span><span style="font-family: Verdana;"> が必要で、各比較でレコードを 3 回移動して交換レコードの位置を取得する必要があります。この場合、比較と移動の数は最大値に達します: </span><span style="font-family: 宋体;"> バブルソートの最悪の時間計算量は: O<img src="/static/imghwm/default1.png" data-src="https://img.php.cn/upload/article/000/000/164/ca8563b0fdd9370c1ec2f8b97a00d59c-0.jpg?x-oss-process=image/resize,p_40" class="lazy" alt="">(n<span   style="max-width:90%">2<sub>)<sup>です。 </sup></sub></span></span></span></p>
<p style="margin-left: 60px;"><span style="color: #003300; font-size: 14px;"> 要約すると、バブルソートの合計平均時間計算量は O<span style="font-family: 宋体;">(n<span style="line-height: 1.5;">2<sub>)<sup></sup></sub></span>です。 </span><span style="line-height: 1.5;"></span></span></p>
<p style="margin-left: 60px;">Java クラシック アルゴリズム バブル ソート コード<strong><span style="line-height: 1.5; color: #003300; font-size: 14px;"></span>:</strong><span style="line-height: 1.5; color: #003300; font-size: 14px;"><pre class="brush:php;toolbar:false">/*
 * 冒泡排序 */public class BubbleSort {
  public static void main(String[] args) {
    int[] arr={6,3,8,2,9,1};
    System.out.println("排序前数组为:");
    for(int num:arr){
      System.out.print(num+" ");
    }
    for(int i=0;i<arr.length-1>arr[j+1]){
          int temp=arr[j];
          arr[j]=arr[j+1];
          arr[j+1]=temp;
        }
      }
    } 
    System.out.println();
    System.out.println("排序后的数组为:");
     for(int num:arr){
       System.out.print(num+" ");
     } 
  }
 }</arr.length-1>

Java クラシック アルゴリズム バブル ソートの詳細については、php 中国語 Web サイトに注目してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
JVMのクラスローダーサブシステムは、プラットフォームの独立性にどのように貢献していますか?JVMのクラスローダーサブシステムは、プラットフォームの独立性にどのように貢献していますか?Apr 23, 2025 am 12:14 AM

クラスローダーは、統一されたクラスファイル形式、動的読み込み、親代表団モデル、プラットフォーム非依存バイトコードを通じて、さまざまなプラットフォーム上のJavaプログラムの一貫性と互換性を保証し、プラットフォームの独立性を実現します。

Javaコンパイラはプラットフォーム固有のコードを作成しますか?説明する。Javaコンパイラはプラットフォーム固有のコードを作成しますか?説明する。Apr 23, 2025 am 12:09 AM

Javaコンパイラによって生成されたコードはプラットフォームに依存しませんが、最終的に実行されるコードはプラットフォーム固有です。 1。Javaソースコードは、プラットフォームに依存しないバイトコードにコンパイルされます。 2。JVMは、特定のプラットフォームのバイトコードをマシンコードに変換し、クロスプラットフォーム操作を保証しますが、パフォーマンスは異なる場合があります。

JVMは、さまざまなオペレーティングシステムでマルチスレッドをどのように処理しますか?JVMは、さまざまなオペレーティングシステムでマルチスレッドをどのように処理しますか?Apr 23, 2025 am 12:07 AM

マルチスレッドは、プログラムの応答性とリソースの利用を改善し、複雑な同時タスクを処理できるため、最新のプログラミングで重要です。 JVMは、スレッドマッピング、スケジューリングメカニズム、同期ロックメカニズムを介して、異なるオペレーティングシステム上のマルチスレッドの一貫性と効率を保証します。

Javaの文脈では、「プラットフォームの独立」とはどういう意味ですか?Javaの文脈では、「プラットフォームの独立」とはどういう意味ですか?Apr 23, 2025 am 12:05 AM

Javaのプラットフォームの独立性とは、書かれたコードがJVMが変更なしでインストールされた任意のプラットフォームで実行できることを意味します。 1)JavaソースコードはBytecodeにコンパイルされ、2)BytecodeはJVMによって解釈および実行されます、3)JVMは、プログラムが異なるオペレーティングシステムで実行されることを確認するために、メモリ管理とガベージコレクション機能を提供します。

Javaアプリケーションは、プラットフォーム固有のバグや問題に遭遇する可能性がありますか?Javaアプリケーションは、プラットフォーム固有のバグや問題に遭遇する可能性がありますか?Apr 23, 2025 am 12:03 AM

JavaApplicationScanIndEDENCOUNTIONPLATFORM-SPECISTESUESUSESEJVM'SABSTRACTION.REASONSINCLUDE:1)NativeCodeandLibraries、2)OperatingSystemDifferences、3)JVMimplementationVariations、および4)HardweardePencies.TomiteTETETETESES、DEVELAPERSHOULD:1)

クラウドコンピューティングは、Javaのプラットフォーム独立の重要性にどのような影響を与えますか?クラウドコンピューティングは、Javaのプラットフォーム独立の重要性にどのような影響を与えますか?Apr 22, 2025 pm 07:05 PM

クラウドコンピューティングにより、Javaのプラットフォームの独立性が大幅に向上します。 1)JavaコードはBytecodeにコンパイルされ、異なるオペレーティングシステムでJVMによって実行され、クロスプラットフォーム操作が確保されます。 2)DockerとKubernetesを使用してJavaアプリケーションを展開して、携帯性とスケーラビリティを向上させます。

Javaのプラットフォームの独立性は、その広範な採用においてどのような役割を果たしましたか?Javaのプラットフォームの独立性は、その広範な採用においてどのような役割を果たしましたか?Apr 22, 2025 pm 06:53 PM

java'splatformendenceallowsdevelopersowritecodeodeonceanceandonitondeviceoros withajvm.

コンテナ化テクノロジー(Dockerなど)は、Javaのプラットフォーム独立性の重要性にどのように影響しますか?コンテナ化テクノロジー(Dockerなど)は、Javaのプラットフォーム独立性の重要性にどのように影響しますか?Apr 22, 2025 pm 06:49 PM

Dockerなどのコンテナ化技術は、Javaのプラットフォームの独立性を置き換えるのではなく、強化します。 1)環境全体の一貫性を確保し、2)特定のJVMバージョンを含む依存関係を管理する、3)展開プロセスを簡素化して、Javaアプリケーションをより順応性と管理しやすくする。

See all articles

ホット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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、