QuickSort实现

import java.util.*;
import java.io.*;

public class QuickSort
{
 private int findPartition(Comparable [] data,int min,int max)
 {
  int left;
  int right;
  Comparable  temp;
  Comparable  partitionElement = data[min];

  left = min;
  right = max;
  
  while (left<right)
  {
   while(data[left].compareTo(partitionElement) <=0 && left<right)
    left++;
   while(data[right].compareTo(partitionElement)>0)
    right--;
   if(left<right)
   {
    temp = data[left];
    data[left] = data[right];
    data[right] = temp;
   }
  }
  
  temp = data[min];
  data[min] = data[right];
  data[right] = temp;
  
  return right;
 }
 
 public void quickSort (Comparable [] data,int s,int e)
 {
  int p;
  if (s<e)
  {
   p=e;
   p=this.findPartition(data,s,p);
   this.quickSort(data,s,p-1);
   this.quickSort(data,p+1,e);
  }
  
 }
 
 public static void main (String [] args) throws IOException
 {
  String inString ;
  StringTokenizer tokenizer;
  Integer [] elements;
  QuickSort qs = new QuickSort();
  
  BufferedReader in = new BufferedReader( new InputStreamReader(System.in));
  
  System.out.println("Please input the size: ");
  inString = in.readLine();
  elements = new Integer[Integer.parseInt(inString)];
  
  
  System.out.println("Enter the numbers of elements : ");
  inString = in.readLine();
  tokenizer = new StringTokenizer(inString);
  for (int i =0; i<elements.length && tokenizer.hasMoreTokens();i++)
  {
   elements[i] = Integer.parseInt(tokenizer.nextToken());
  }
  
  qs.quickSort(elements,0,elements.length-1);
  
  System.out.println("after sorted :");
  for (int i=0;i<elements.length;i++)
  {
   System.out.println(elements[i]);
  }
  
 }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值