/*
* 快速排序算法 用到了 <分治法>《递归算法》
*/
package com.xiahui;
public class QuickSort {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
int[] a = { 2, 19, 33, 4, 6, 9, 0 };
QuickSort quickSort = new QuickSort();
quickSort.quickSort(a, 0, 6);
for (int i = 0; i < a.length; i++) {
System.out.print(a[i] + " ");
}
}
public void quickSort(int[] r, int low, int high) {
if (low < high) {
int pa = partition(r, low, high);
quickSort(r, low, pa - 1);// 递归算法
quickSort(r, pa + 1, high);// 递归算法 一定要 特别精通
}
}
private int partition(int[] r, int low, int high)// 传进来一个数组可以对任意两个下标之间进行快速排序
{
int pivot = r[low]; // 使用r[low]作为枢轴元素
while (low < high) // 从两端交替向内扫描
{
while (low < high && r[high] > pivot) { //从右往前扫描
high--;
}
r[low] = r[high]; // 将比pivot 小的元素移向低端
while (low < high && r[low] < pivot) {
low++;
}
r[high] = r[low]; // 将比pivot 大的元素移向高端
}
r[low] = pivot; // 设置枢轴
return low; // 返回枢轴元素位置
}
}
分享到:
相关推荐
快速排序是一种高效的排序算法,由英国计算机科学家C.A.R....总的来说,这个压缩包提供了一个非递归实现快速排序的完整示例,通过自定义栈的数据结构,实现了快速排序算法,适用于理解和学习快速排序的非递归实现方式。
### 快速排序的递归简洁实现 #### 分区函数(Partition) 分区是快速排序的核心步骤,其主要目标是选择一个基准元素(pivot),并将所有小于等于该基准的元素移动到基准的左边,所有大于该基准的元素移动到基准的...
通常的快速排序是采用递归实现的,但这里我们讨论的是非递归版本。 非递归实现快速排序的关键在于使用栈来模拟递归调用的过程。在递归版本中,我们首先选择一个基准元素(pivot),然后将数组分为两部分:小于基准...
### JAVA快速排序(递归实现与非递归堆栈模拟实现) #### 一、递归实现的快速排序 快速排序是一种非常高效的排序算法,它的基本思想是通过一趟排序将待排记录分隔成独立的两部分,其中一部分的所有记录都比另一...
3. **递归排序**:对基准左边的子数组和右边的子数组分别进行快速排序,这个过程通过递归调用快速排序函数来实现。如果子数组为空,递归结束;否则,重复步骤1和2。 4. **合并结果**:由于排序是就地进行的,不需要...
总的来说,快速排序和折半查找是计算机科学中不可或缺的算法,通过递归和分治策略,可以在Java中高效地实现这些算法,并结合界面设计,为用户提供直观的交互体验。在实际项目中,理解和掌握这些算法有助于优化数据...
此文档是快速排序的递归与非递归的具体实现代码
快速选择算法是基于快速排序的一种高效选择算法,用于在未排序的数据集合中找到第k小(或第k大)的元素。它由C.A.R. Hoare在1960年提出,是线性时间复杂度的算法,在平均情况下表现优秀。在本主题中,我们将深入探讨...
快速排序已经是很成熟的排序方法 递归的缺点就是当排序数据量大时,系统堆栈会溢出 递归的实质是在堆栈中不断保存现场,但是现场的数据量是很大的 网上给出了堆栈实现的伪码算法,但是这里面存在很多的BUG 这个程序...
"C语言学习之排序数据结构链表堆排序希尔排序快速排序递归排序" 本资源主要介绍了C语言中的排序算法,包括链表、堆排序、希尔排序、快速排序和递归排序等五种方法。同时,文章还提供了每种排序方法的原理、流程图和...
它基于分治策略,通常使用递归实现。然而,递归算法可能会导致栈溢出,特别是在处理大规模数据时。为了克服这个问题,我们可以采用非递归的方式来实现快速排序,这种方式不依赖系统栈,而是通过迭代来完成排序过程。...
9. 递归的归并排序:归并排序通常使用递归实现,通过递归调用自身对数组的前半部分和后半部分进行排序,然后用归并操作合并结果。这种递归方式使算法具有清晰的逻辑结构。 10. 基数排序:基数排序是一种非比较型...
2. **递归调用**:C语言支持函数递归,可以用于实现快速排序的递归过程。 3. **内存管理**:虽然快速排序本身并不涉及大量的内存分配和释放,但在大规模数据处理时,递归深度过深可能导致栈溢出,需要考虑适当的优化...
非递归版本的快速排序则是不使用递归实现这一算法。 在给定的文档中,`quickpass` 函数实现了快速排序的主要逻辑,即“主元交换”(partition)过程。`quicksort` 函数则负责整体的控制,包括栈的管理以及主元交换...
用栈实现的快速排序,避免了原来的递归算法
这一过程可以通过递归实现,直到所有元素都排好序。 以下是快速排序的C语言实现示例: ```c void quickSort(int arr[], int left, int right) { if (left ) { int pivot = partition(arr, left, right); ...
课件中提到的快速排序递归实现,就是利用递归在子数组上重复执行排序过程,直到所有元素都在正确位置上。 总的来说,递归是编程中的强大工具,它能简化问题表示,但同时也需要谨慎使用,以避免性能问题。理解和掌握...
在C#中实现快速排序,我们通常会用到递归函数。首先,我们需要一个方法来选取枢轴,这可以是数组的第一个元素、最后一个元素,或者数组中间的元素,也可以是三数取中法,即取首、尾、中间三个元素的中位数作为枢轴,...
链表是一种重要的数据结构,它在计算机科学...总之,C语言实现链表快速排序是一项挑战性的任务,它涉及到对链表操作和递归算法的深入理解。通过这个实践,可以提升对数据结构和算法的掌握,同时也有助于提高编程技巧。