JAVA 快速排序

2 篇文章 0 订阅
1 篇文章 0 订阅
package com.yss.newrisk.custom.Test.a;
 
 
public class Test1 {
    
     public static int[] Arr1 = {5,233,54,23,78,3,56,2,8,46};
    
     public static void main(String[] args) {
          System.out.println("修改前:");
          for (int i = 0; i < Arr1.length; i++) {
              System.out.print(Arr1[i] + " ");
            }
 
          System.out.println("");
         
          System.out.println("修改后:");
          for (int i = 0; i < Arr1.length; i++) {
              System.out.print(Arr1[i] + " ");
            }
         
     }
    
    
     //iL:起始坐标;iR:结束坐标
     public static void ChangeArr2(int iL,int iR) {
          int iFlagValue;     //基准值,默认为起始坐标的值
          int iTempValue;     //临时变量
          int tmpL;      //游标,左边坐标
          int tmpR;      //游标,右边坐标
         
          if(iL >= iR) return;
         
          tmpL = iL;
          tmpR =iR;
          iFlagValue = Arr1[tmpL];
         
          while(tmpR > tmpL)
          {
               //从右向左找小于基准值的位置
               while(Arr1[tmpR] >= iFlagValue && tmpR > tmpL)
               {
                    tmpR--;
               }
               //从左向右找大于基准值的位置
               while(Arr1[tmpL] <= iFlagValue && tmpR > tmpL)
               {
                    tmpL++;
               }
               //如果不交叉,将交换位置值
               if(tmpR > tmpL)
               {
                    iTempValue = Arr1[tmpL];
                    Arr1[tmpL] = Arr1[tmpR];
                    Arr1[tmpR] = iTempValue;
               }
          }
          //最后将基准值替换到最后的位置
          if(tmpL > iL){
               Arr1[iL] = Arr1[tmpL];
               Arr1[tmpL] = iFlagValue;
          }
 
          ChangeArr2(iL,tmpL-1);
          ChangeArr2(tmpL+1,iR);
     }
 
}
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值