快速排序

本文介绍了一种快速排序算法的Java实现方法。通过递归方式,选取基准元素并对数组进行分区,实现了对整型数组的有效排序。文章展示了完整的排序过程及测试代码。

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

快速排序的代码:

public class QSort {
   
    public static void QuickSort(int[] pData,int left,int right)
    { 
      int i,j;
      int middle,temp;
      i = left;
      j = right;
      middle = pData[left];
      while(true)
      {
          while((++i)<right-1 && pData[i]<middle);
          while((--j)>left && pData[j]>middle);
          if(i>=j)
              break;
          temp = pData[i];
          pData[i] = pData[j];
          pData[j] = temp;
      }
 
      pData[left] = pData[j];
      pData[j] = middle;
     
      if(left<j) 
        QuickSort(pData,left,j);
 
 
      if(right>i) 
        QuickSort(pData,i,right);
    }
 
    public static void main(String[] args){
        int[] pData = new int[10];
        for(int i = 0; i< 10; i++)
            pData[i] = (int)(Math.random()*100);
       
        for(int i = 0; i<pData.length; i++)
            System.out.print(pData[i]+" ");
       
        QSort.QuickSort(pData, 0, pData.length);
       
        System.out.println("/n***********************");
       
        for(int i = 0; i<pData.length; i++)
            System.out.print(pData[i]+" ");
    }
 
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值