`
aaron-han
  • 浏览: 27293 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

算法基础之快速排序

阅读更多
  算法一直是一块短板,今后会陆续写一些常用算法的实现,希望和大家一起探讨学习。
  快速排序是排序算法中最经典的一个,原理就不再赘述了,直接上代码。欢迎大家拍砖指导。
import java.util.Arrays;

/**
 * 快速排序
 * 
 * @author aaron-han
 * 
 */
public class QuickSort {

	public static void main(String[] args) {
		int[] arr = com.utils.Utils.randomIntArray();
		quickSort(arr, 0, arr.length - 1);
		System.out.println(Arrays.toString(arr));
	}

	public static void quickSort(int[] arr, int low, int high) {
		if (low < high) {
			int mid = partition(arr, low, high);
			quickSort(arr, low, mid - 1);
			quickSort(arr, mid + 1, high);
		}
	}

	private static int partition(int[] arr, int low, int high) {
		int pivot = arr[low];
		int i = low;
		int j = high;
		while (i < j) {
			while (i < j && arr[j] >= pivot) {
				j--;
			}
			while (i < j && arr[i] <= pivot) {
				i++;
			}
			if (i < j) {
				swap(arr, i, j);
			}
		}
		swap(arr, low, j);
		return j;
	}

	private static void swap(int[] arr, int i, int j) {
		int temp = arr[j];
		arr[j] = arr[i];
		arr[i] = temp;
	}

}
分享到:
评论
2 楼 rexyoung 2012-03-30  
不用多线程也能写出并发的 Quick Sort
http://www.cnblogs.com/rexyoung/archive/2012/03/29/2422955.html
1 楼 rexyoung 2012-03-21  
你的程序有一些小毛病,比如:

1,pivot 在 19 行是一个数组下标,但在 27 却是一个数组元素的值,很误导;
2,swap 在 partition 之外也调用了,这是我第一次看见这样写的 QuickSort;
3,36 行防止越界应该是 high 吧?
4,swap 不应该独立成为函数,一是太简单,二是多少增加了一些开销;
5,总是选第一个数组元素作为 pivot 这有问题。不是说不可以,但当数组本身就接近有序的话,每次 partition 就只能分出个别数组元素,成为了最坏的情况。其他选法也会有最坏的情况出现,但概率小多了。

这些都是小事,最糟糕的是这个程序是错的。你试试这个数组:{ 2, 1, 2, 2 }

原因是对 QuickSort 的精神没有吃透,特别是 pivot,要知道 pivot 可以选不在数组中出现的值。所以 41 行处,如果 arr[i] 和 arr[j] 的值都是 pivot 的话,swap 后又没有调整 i 和 j 的值,于是就死循环了。

相关推荐

    快速排序的并行算法

    #### 快速排序基础概念 快速排序是一种非常高效的排序算法,由C.A.R. Hoare在1962年提出。它采用分治法的思想来对数组进行排序。具体操作是选择一个元素作为基准(pivot),然后通过一趟排序将待排序的数据分割成...

    FPGA并行快速排序算法-位宽可设

    一、快速排序算法基础 快速排序是一种高效的排序算法,由C.A.R. Hoare在1960年提出。它的基本思想是通过一趟排序将待排序的数据分割成独立的两部分,其中一部分的所有数据都比另一部分的所有数据都要小,然后再按此...

    排序算法编程 堆排序 快速排序

    本主题将深入探讨四种常见的排序算法:堆排序、快速排序以及两种未在标题中明确提到但同样重要的排序方法——基数排序和计数排序。 首先,让我们详细了解一下堆排序。堆排序是一种基于比较的排序算法,利用了数据...

    并行计算实验快速排序的并行算法

    并行计算实验快速排序的并行算法主要涉及的是在大规模数据处理中提高效率的方法,它利用了并行计算的优势来加速传统的快速排序算法。快速排序是一种广泛应用的分治策略排序算法,由C.A.R. Hoare在1960年提出。它的...

    快速排序算法和冒泡排序效率对比

    相比之下,快速排序由C.A.R. Hoare在1960年提出,是一种分治策略的体现。快速排序的基本思想是选取一个基准值,将数组分为两部分:一部分的元素都小于基准,另一部分的元素都大于或等于基准。然后对这两部分分别进行...

    C++语言的算法实现包括插入排序冒泡排序堆排序快速排序

    快速排序是C++中最常用的排序算法之一,由英国计算机科学家C.A.R. Hoare提出。它使用分治策略,选择一个基准元素,将数组分为两部分,一部分的所有元素都小于基准,另一部分的元素都大于基准,然后递归地对这两部分...

    快速排序算法以及归并算法

    根据给定的文件信息,我们将深入探讨两种经典的排序算法——快速排序和归并排序,并结合Java语言实现进行详细解析。 ### 快速排序算法 快速排序是一种高效的排序算法,采用分而治之的策略,其核心思想是选择一个...

    并行计算实验快速排序的并行算法.doc

    在现代计算机科学中,快速排序是...通过在多处理器系统上实现快速排序算法,学生能够亲身体验并行计算如何提升算法效率,同时熟悉MPI系统的通信机制,为将来在分布式系统和高性能计算领域的研究与工作打下坚实的基础。

    C经典算法之快速排序法(二)

    ### C经典算法之快速排序法(二) #### 知识点概述 本篇文章将深入探讨快速排序算法的一个改进版本,并通过具体的代码实现来展现这一优化思路。在快速排序法(一)的基础上,本文重点关注轴的选择对算法性能的影响...

    基础排序 冒泡排序 插入排序 快速排序 双路快速排序 三路快速排序 堆排序.zip

    冒泡排序是最基础的排序算法之一,其工作原理类似于水底下的气泡逐渐上浮。通过反复遍历待排序的序列,比较相邻元素并交换位置,使较大的元素逐渐“浮”到序列的末尾。冒泡排序的时间复杂度在最坏情况下为O(n²),...

    算法设计实验报告-快速排序和归并排序

    **算法设计实验报告** 在计算机科学中,排序是数据处理中的基本...通过本实验报告,读者不仅能掌握快速排序和归并排序的基本原理,还能通过实践提升对算法设计与分析的理解,为进一步深入学习和应用排序算法奠定基础。

    JAVA冒泡排序和快速排序算法

    快速排序在处理大规模数据时表现出优秀的性能,是实际应用中最常用的排序算法之一。 在JAVA中,实现这两种排序算法可以使用面向对象的特性,创建一个类如`MaopaoKuaisu.java`,在这个类中定义两个方法,分别实现...

    超快速排序算法,性能优于快速排序算法和基数排序算法

    在计算机科学中,排序算法是一种重要的基础算法,被广泛应用于各种系统软件和应用软件之中。传统的排序算法如快速排序和基数排序各有优缺点:快速排序算法因其简洁的结构和较好的平均性能而广受欢迎,但在最坏的情况...

    算法实验(快速排序,归并排序,回溯算法,N后问题等。)

    快速排序是一种高效的排序算法,由英国计算机科学家C.A.R. Hoare在1960年提出。它的基本思想是分治法,通过选取一个“基准”元素,将数组分为两个子数组,使得左边的元素都小于基准,右边的元素都大于基准。然后对这...

    JAVA排序算法: 直接插入,希尔排序,选择排序,堆排序,冒泡排序,快速排序,归并排序

    1. **直接插入排序**:直接插入排序是最基础的排序算法之一。它的工作原理是将待排序的元素逐个与已排序的部分进行比较,找到合适的位置插入。这种算法对于小规模或部分有序的数据集表现较好,但对于大规模无序数据...

    算法基础:冒泡排序;直接插入排序;希尔排序;快速排序;堆排序;归并排序;基数排序_Algorithm.zip

    算法基础:冒泡排序;直接插入排序;希尔排序;快速排序;堆排序;归并排序;基数排序_Algorithm

    基础排序 冒泡排序 插入排序 快速排序 双路快速排序 三路快速排序 堆排序 位运算

    **双路快速排序**是在快速排序的基础上进行优化,主要解决了快速排序在处理含有大量重复元素时效率下降的问题。双路快排会把小于基准的元素放在基准左边,大于基准的元素放在右边,同时,相等的元素会被放在基准的一...

    7种常用排序算法实现(C++)(冒泡排序、选择排序、直接插入排序、希尔排序、堆排序、归并排序以及快速排序)

    冒泡排序是最基础的排序算法之一,通过重复遍历待排序序列,比较相邻元素并交换位置来实现排序。如果前一个元素大于后一个元素,它们就会交换位置,这样最大的元素会逐渐"冒泡"到序列末尾。时间复杂度为O(n^2)。 2...

Global site tag (gtag.js) - Google Analytics