原題: Java の古典的なアルゴリズム: バブルソート (バブルソート)
バブルソートとは何ですか?
バブル ソートは、順序に基づいて要素をペアごとに比較する単純な並べ替えアルゴリズムです。順序が大から小の場合、2 つの要素が相互に比較されると、大きい方が最初にランク付けされ、そうでない場合は、大きい方が後にランク付けされます。バブル選別は大から小への選別と小から大への選別に分かれます。
原則: 2 つの隣接する要素を比較し、値が大きい方の要素を右端に入れ替えます。
アイデア: 2 つの隣接する数値を順番に比較し、小数を前に、大きい数値を後ろに置きます。つまり、最初のパスでは、まず 1 番目と 2 番目の数値を比較し、小数点を前に、大きな数値を後ろに置きます。次に、2 番目の数値と 3 番目の数値を比較し、小数を前に、大きな数値を後ろに置きます。最後の 2 つの数値を比較するまで同様に、小数を前に、大きな数値を後ろに置きます。すべての並べ替えが完了するまで、最初の手順を繰り返します。
例: 配列をソートするには: int[] arr={6,3,8,2,9,1};
最初のソート:
最初のソート: 6 3、6は3より大きい、交換位置: 3 6 8 2 9 1
2番目の並べ替え: 6 と8 比較: 6は、位置を交換せずに8より小さい: 3 6 8 2 9 1
3番目の並べ替え: 8と2 比較してください 8は2より大きい、位置を入れ替える: 3 6 2 8 9 1
、8は9より小さい はより大きい1 、位置の交換: 3 6 2 8 1 9 最初のトリップで合計 5
の比較が行われ、ソート結果:3 6 2 8 1 9 ------------------------------------------------- -------------------- 2回目の並べ替え: 1回目の並べ替え: 3と6、3 の比較は6より小さい、位置を交換せず: 3 6 2 8 1 9 2番目の並べ替え: 6と2の比較、 6 はより大きい2、位置交換: 3 2 6 8 1 9 3番目の並べ替え: 6と8の比較、6より大きい8、位置の交換なし: 3 2 6 8 1 9 4番目の並べ替え: 8と1を比較すると、8は1より大きい、位置を交換します: 3 2 6 1 8 9 2 回目の旅行では、合計 4 の比較が実行され、ソート結果は次のとおりです: 3 2 6 1 8 9 --- ---------------------------------------------------- ------- -------- 3回目の並べ替え: 1回目の並べ替え: 3と2を比較すると、3はより大きい2、位置を交換: 2 3 6 1 8 9 2番目の並べ替え: 3と6を比較すると、3の方が少ない6より 、位置を交換しないでください: 2 3 6 1 8 9 3番目の並べ替え: 6と1を比較すると、6は1より大きく、位置を入れ替えます: 2 3 1 6 8 9 2つ目合計 3 の比較が行われ、 並べ替え結果: 2 3 1 6 8 9 ---------------------- -------------------------------------------------- -- 4 回目の並べ替え: 最初の並べ替え: 2 と 3 を比較すると、 2 は 3 より小さく、位置は交換されません: 2 3 1 6 8 9 2 番目の並べ替え: 3 と 1 を比較すると、3 は 1 より大きいため、位置を交換します。 2 1 3 6 8 9 2回目の旅行は合計で の比較、の並べ替え結果: 2 1 3 6 8 9----------------- ------------ -------------------------------------- -- 5回目の並べ替え: 最初の並べ替え: 2 1を比較すると、2が1より大きく、位置を入れ替えます: 1 2 3 6 8 9 2 回目の旅行 合計 の比較が行われ、 並べ替え結果: 1 2 3 6 8 9-------------- ------------ -------------------------------------- ------------- 最終結果: ------ ------------------------ ------------------------ -------- 次のことがわかります: 個の数値を並べ替える必要があり、合計 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プログラムの一貫性と互換性を保証し、プラットフォームの独立性を実現します。

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

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

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

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

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

java'splatformendenceallowsdevelopersowritecodeodeonceanceandonitondeviceoros withajvm.

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


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

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

Dreamweaver Mac版
ビジュアル Web 開発ツール

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