java快速排序,快速排序算法简介
快速排序(Quick Sort)是一种高效的排序算法,它选用分治法(Divide and Conquer)的战略来把一个序列分为较小和较大的两个子序列,然后递归地排序这两个子序列。快速排序的均匀时刻复杂度为O,在最坏的状况下为O。
快速排序的根本进程如下:
1. 挑选基准值(Pivot):从数列中挑出一个元素,作为基准值。2. 分区(Partitioning):重新排列数列,一切比基准值小的元素摆放在基准前面,一切比基准值大的元素摆在基准的后边(持平的数能够就任一边)。在这个分区退出之后,该基准就处于数列的中心方位。这个称为分区(partition)操作。3. 递归排序子序列:递归地将小于基准值元素的子序列和大于基准值元素的子序列排序。
以下是快速排序算法的Java完结:这是快速排序的成果。关于给定的测验数组 ``,排序后的数组为 ``。
如果您需要将这个完结转换为Java代码,请告诉我,我能够帮助您。
快速排序算法简介
快速排序(Quick Sort)是一种高效的排序算法,由英国计算机科学家Tony Hoare在1960年创造。它选用分治法战略,经过递归地将大问题分解为小问题来处理。快速排序在均匀和最坏状况下的时刻复杂度分别为O(n log n)和O(n^2),但由于其常数因子较小,实践运转速度一般比其他O(n log n)算法要快。
快速排序的根本原理
快速排序的中心思维是挑选一个基准元素(pivot),然后将数组分为两个子数组:一个包含小于基准的元素,另一个包含大于基准的元素。这个进程称为分区(partitioning)。递归地对这两个子数组进行快速排序,直到一切子数组都排序完结。
快速排序的分区进程
分区进程是快速排序算法的关键进程。以下是一个简略的分区算法完结,它将数组分为两个部分,左面部分的一切元素都小于或等于基准,右边部分的一切元素都大于基准:
```java
public static int partition(int[] array, int low, int high) {
int pivot = array[high]; // 挑选最右边的元素作为基准
int i = low - 1; // i是小于基准的元素的最终一个索引
for (int j = low; j 快速排序算法经过递归调用本身来对子数组进行排序。以下是一个快速排序的递归完结示例:
```java
public static void quickSort(int[] array, int low, int high) {
if (low 快速排序的均匀时刻复杂度为O(n log n),这是由于每次分区操作能够将问题规划削减到本来的一半。在最坏的状况下,即数组现已有序或逆序时,快速排序的时刻复杂度会退化到O(n^2)。这种状况下,挑选一个适宜的基准元素变得尤为重要。
挑选适宜的基准元素
挑选第一个元素作为基准。
挑选最终一个元素作为基准。
挑选中心的元素作为基准。
挑选随机元素作为基准。
运用三数取中法挑选基准。
快速排序的Java完结
以下是一个完好的快速排序算法的Java完结,包含分区和递归排序进程:
```java
public class QuickSort {
public static void quickSort(int[] array, int low, int high) {
if (low < high) {
int pi = partition(array, low, high);
quickSort(array, low, pi - 1);
quickSort(array, pi 1, high);
}
}
public static int partition(int[] array, int low, int high) {
int pivot = array[high];
int i = low - 1;
for (int j = low; j < high; j ) {
if (array[j] <= pivot) {
i ;
int temp = array[i];
array[i] = array[j];
array[j] = temp;
}
}
int temp = array[i 1];
array[i 1] = array[high];
array[high] = temp;
return i 1;
}
public static void main(String[] args) {
int[] array = {10, 7, 8, 9, 1, 5};
int n =
相关
-
php和mysql,构建高效动态网站详细阅读
PHP(HypertextPreprocessor,超文本预处理器)是一种开源的服务器端脚本言语,首要用于网页开发,能够嵌入HTML中运用。PHP在网页开发中特别盛行,由于它...
2025-01-07 4
-
PHP研制工程师,技术革新下的工作开展之路详细阅读
PHP研制工程师是一个专心于运用PHP编程言语进行软件开发和体系保护的专业职位。PHP(HypertextPreprocessor)是一种广泛用于Web开发的服务器端脚本言语...
2025-01-07 3
-
女子监狱ruby,Ruby Rose的精彩演绎详细阅读
鲁比·罗丝(RubyRose)在美剧《女子监狱》(OrangeIstheNewBlack)中扮演了一个人物,引起了广泛重视。她的职业生计从音乐掌管人起步,后来做过电台...
2025-01-07 1
-
java署理形式, 署理形式概述详细阅读
署理形式(ProxyPattern)是一种规划形式,用于在不改动原始方针的基础上,为原始方针供给一个署理,以操控对这个方针的拜访。署理形式答应你增加额定的功用到现有的类,而不...
2025-01-07 3
-
python怎样翻开,新手入门攻略详细阅读
在Python中,翻开一般指的是翻开文件或网络资源。下面我会别离介绍怎样翻开文件和怎样翻开网络资源。翻开文件在Python中,你能够运用内置的`open`函数来翻开文件。...
2025-01-07 3
-
go读音,深入探讨“go”的读音及其在英语中的使用详细阅读
Go是一个英文单词,它有多种含义和用法,详细取决于上下文。在中文中,go通常被翻译为去,但这个翻译或许并不精确,由于go在英文中有更广泛的含义。例如,go能够表明...
2025-01-07 2
-
rust装备,rust装备要求详细阅读
Rust是一种体系编程言语,以其内存安全、并发性、零本钱笼统和丰厚的类型体系而出名。要装备Rust,您需求遵从以下进程:1.装置Rust:拜访Rust官方网...
2025-01-07 2
-
swift报文格局,SWIFT报文格局概述详细阅读
Swift(SocietyforWorldwideInterbankFinancialTelecommunication)是一种世界银行间电文传输体系,用于金融机构之...
2025-01-07 2
-
php开展趋势,从光辉到未来展望详细阅读
PHP的开展趋势技能方面:功用优化:PHP一向致力于进步功用,例如经过JIT编译、改善内存办理等。未来,功用优化仍然是重要方向,以应对日益杂乱的使用需求。新言语...
2025-01-07 3
-
奇特宝物go小说,实际国际的冒险之旅详细阅读
1.快眼看书:供给《奇特宝物:GO》的最新章节、全文阅览和全本TXT下载服务。这本小说情节跌宕起伏、扣人心弦,是一本情节与文笔俱佳的网游竞技小说。2.飞卢小说网:...
2025-01-07 2