数据结构与算法复习第一弹(快速排序)

本文介绍了快速排序的基本思想,它是基于分治法的一种高效排序算法。文章详细解释了通过一趟排序将数据分割成独立的两部分的过程,并递归地对这两部分继续执行快速排序,最终实现整个数据集的有序排列。提供了快速排序的Java实现代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

算法思想:

快速排序是基于分治法的思想,是冒泡排序的改进型。快速排序由C. A. R. Hoare在1962年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。快速排序的平均时间复杂对为O(n×log(n)),最坏情况时间复杂度为O(n^2)。(后续了解详情)


代码实现:


package com.algorithm.test;

/**
 * 快速排序练习
 * @project 算法练习
 * @author zhou
 * @date 2017年12月18日
 * @version 1.0.0
 * Copyright(c) YIJIAN All Rights Reserved
 */

public class QuickSort {

    /**
     * 快速排序,从小到大
     * @author zhou
     * @param array 需要排序的数组
     * @param low   前置数组下标
     * @param high  后置数组下标
     */
    public static int QuickSort(int[] array,int low,int high){
        int flag = array[low];
        while(low<high) {
            while(array[high]>=flag&&high>low) {
                high--;
            } 
            array[low] = array[high];
            while(array[low]<=flag&&high>low) {
                low++;
            }
            array[high] = array[low];
        }
        array[high]=flag;
        return high;
    }
    public static void Sort(int[] array,int low,int high){
        if(low>=high){
            return ;
        }
        int index=QuickSort(array,low,high);
        Sort(array,low,index-1);
        Sort(array,index+1,high);
    }
    public static void main(String[] args){
        int array[] = {1,54,6,3,78,34,12,45};
        int low = 0;
        int i = 0;
        int high = array.length-1;
        Sort(array,low,high);
        while(i<array.length-1) {
            System.out.print(array[i]+"、");
            i++;
        }
    }
}

2017年12月18日陕西易唐云网智能科技有限公司

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值