検索

Java でのクイックソート

Oct 22, 2019 pm 03:53 PM
java

クイックソートの原理

クイックソートはバブルソートを改良したもので、小さい値を一つずつ比較するのがバブルソートです。 value はソートの目的を達成するためにもう一方の端に置かれます。

Java でのクイックソート

クイックソートは、最初に臨界値を選択し、臨界値より小さい値を一方の端に配置し、臨界値より大きい値を配置します。反対側では。前項の方法を繰り返し、臨界値を超えた辺を2回分割して… データを並べ替えたら、クイックソート全体が完了します。

クイック ソート アルゴリズム

コア アルゴリズム:

//QuickSort
while(i < j) {
		while(num[j] > tmp && j > i)
			--j;
		while(num[i] <= tmp && i < j) {
			++i;
		}
		if(i < j) {
			t = num[i];
			num[i] = num[j];
			num[j] = t;
		}
	}
	num[left] = num[i];
	num[i] = tmp;

以下は完全な QuickSort プログラムです:

//QuickSort.java
public class QuickSort {
	public static void main(String[] args) {
		int[] num = {10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
		
		System.out.print("Qriginal array is:");
		for (int i = 0; i < num.length; i++) {
			System.out.print(num[i] + " ");
		}
		System.out.println();
		
		//QuickSort
		quicksort(num, 0, 9);
		
		System.out.print("Sorted array is:");
		for (int i = 0; i < num.length; i++) {
			System.out.print(num[i] + " ");
		}
		System.out.println();
	}
	
	public static void quicksort(int[] num, int left, int right) {
		if(left > right)
			return;
		int tmp, i, j, t;
		tmp = num[left];
		i = left;
		j = right;
		while(i < j) {
			while(num[j] > tmp && j > i)
				--j;
			while(num[i] <= tmp && i < j) {
				++i;
			}
			if(i < j) {
				t = num[i];
				num[i] = num[j];
				num[j] = t;
			}
		}
		num[left] = num[i];
		num[i] = tmp;
		quicksort(num, left, i - 1);
		quicksort(num, i + 1, right);
	}
}

プログラムの出力を次の図に示します。

Qriginal array is:10 9 8 7 6 5 4 3 2 1
Sorted array is:1 2 3 4 5 6 7 8 9 10

クイック ソートは他のソート方法より効率的であるため、現時点ではクイック ソートが最適な一般的なソート方法です。 QuickSort の時間計算量は O(nlogn) です。

以上がJava でのクイックソートの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事はCSDNで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
mybatisで@resulttypeアノテーションを正しく使用する方法は?mybatisで@resulttypeアノテーションを正しく使用する方法は?Apr 19, 2025 pm 04:12 PM

MyBatisフレームワークを研究するとき、開発者はしばしば注釈に関するさまざまな問題に遭遇します。よくある質問の1つは、@resulttypeアノテーションを正しく使用する方法です...

自然言語処理技術を使用して人事データを効率的に照会する方法は?自然言語処理技術を使用して人事データを効率的に照会する方法は?Apr 19, 2025 pm 04:09 PM

自然言語処理技術を使用して人事データを最新の企業に照会する方法は、人事データの管理とQueryが一般的な要件です。私たちが...

Springboot Multi-Dataソース構成の下で、データベースアクセスが昼間、夜間に速い理由は何ですか?Springboot Multi-Dataソース構成の下で、データベースアクセスが昼間、夜間に速い理由は何ですか?Apr 19, 2025 pm 04:06 PM

Springboot Projectのデータベースアクセスパフォーマンスの問題マルチデータソース構成この記事は、Springboot ProjectでMulti-Dataソース構成にAtomikosを使用することを目指しています...

noclassdeffounderrorは、JavaプロジェクトがJARにパッケージ化された後に登場します。JDKバージョンの互換性の問題をトラブルシューティングする方法は?noclassdeffounderrorは、JavaプロジェクトがJARにパッケージ化された後に登場します。JDKバージョンの互換性の問題をトラブルシューティングする方法は?Apr 19, 2025 pm 04:03 PM

Javaプロジェクトを実行可能なJARファイルにパッケージ化すると、noclassdeffounderrorの問題に遭遇します。多くのJava開発者は...

Intellijのアイデアのひび割れプロセスを分析し、登録に責任を負うLIBまたはクラスを見つける方法は?Intellijのアイデアのひび割れプロセスを分析し、登録に責任を負うLIBまたはクラスを見つける方法は?Apr 19, 2025 pm 04:00 PM

プログラミングの世界でのIntellijideaのクラッキングの分析方法に関して、Intellij ...

JavaとJavacvを使用してビデオ品質を改善する方法は?効果が限られているのはなぜですか?JavaとJavacvを使用してビデオ品質を改善する方法は?効果が限られているのはなぜですか?Apr 19, 2025 pm 03:57 PM

問題の紹介:改善されたビデオ品質は、特に低解像度ビデオの処理、Java言語の使用方法など、ビデオ処理の重要な部分です。

Springbootで@RequestBodyアノテーションを取得して、非JSON形式で文字列パラメーターを正しく受信するにはどうすればよいですか?Springbootで@RequestBodyアノテーションを取得して、非JSON形式で文字列パラメーターを正しく受信するにはどうすればよいですか?Apr 19, 2025 pm 03:54 PM

スプリングブートアプリケーションの処理では、リクエストパラメーターを正しく受信する方法の問題に遭遇することがよくあります。特にパラメーター形式が一般的なJSONではない場合、もっと...

Javaで同時ハッシュマップを宣言するときに、静的キーワードの追加はどのような影響を与えますか?Javaで同時ハッシュマップを宣言するときに、静的キーワードの追加はどのような影響を与えますか?Apr 19, 2025 pm 03:51 PM

JavaプログラミングのJavaで並行ハッシュマップを宣言するときに静的を追加することの影響、Concurrenthashmap ...

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

AI Hentai Generator

AI Hentai Generator

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

ホットツール

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

DVWA

DVWA

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