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 =
猜你喜欢
- 后端开发
python 浅仿制,python 浅仿制 深仿制
在Python中,浅仿制是指创立一个新的目标,它包括原始目标中元素的引证,而不是目标的副本。这意味着,假如原始目标中的元素是可变目标(如列表、字典、类实例等),那么在浅仿制中,这些可变目标将不会仿制,而是被同享。这或许会导致原始目标和浅仿制...
2025-01-07 0 - 后端开发
php查询
您好,您想了解PHP查询方面的什么内容呢?例如查询数据库、查询数据表、查询数据等。请告诉我您的详细需求,我会极力为您回答。PHP查询:深化了解与高效实践PHP作为一种盛行的服务器端脚本语言,广泛应用于Web开发范畴。在PHP编程中,查询是...
2025-01-07 0 - 后端开发
python条件句子,if 句子
在Python中,条件句子用于依据不同的条件履行不同的代码块。主要有两种类型的条件句子:`if`句子和`ifelse`句子。1.`if`句子`if`句子是最根本的条件句子,它依据条件的真假来决议是否履行某个代码块。```pythonif...
2025-01-07 0 - 后端开发
r言语脚本,从入门到实践
好的,我会极力为您供给协助。请您供给详细的R言语脚本内容或问题,我会根据您供给的信息进行回答或修正。如果您需求学习R言语的基础知识,也能够告诉我,我会为您预备一些基础教程。R言语脚本编写攻略:从入门到实践跟着大数据年代的到来,数据剖析已经成...
2025-01-07 1 - 后端开发
r言语课程,从入门到通晓的数据科学之旅
以下是几门引荐的R言语课程,合适不同根底的学习者:1.小白速成与实践全30课渠道:哔哩哔哩课程内容:包含R言语的介绍、装置、获取协助、作业空间办理、R包的运用、成果的重用、大数据集处理等。2.运用计算与R言语...
2025-01-07 0 - 后端开发
go pee,探究“Go Pee”的意义与用法
Itseemslikeyou'reusingacasualexpression.Gopeeisaninformalwayofsayinggotothebathroomorusetherestro...
2025-01-07 0 - 后端开发
c言语强制类型转化,什么是强制类型转化?
在C言语中,强制类型转化是一种将一个表达式的值从一种类型转化为另一种类型的方法。这通常是经过在类型名前加上括号来完成的。强制类型转化在C言语中非常常见,尤其是在进行算术运算、函数调用、指针操作等场景中。强制类型转化的根本语法如下:```c`...
2025-01-07 0 - 后端开发
php读取excel文件
1.PHPExcel:这是一个盛行的PHP库,用于读取和写入Excel文件(2003和2007格局)。2.PHPSpreadsheet:这是PHPExcel的继承者,支撑读取和写入Excel文件(2003、2007、2010、2013、...
2025-01-07 0