Yesky首页| 产品报价| 行情| 手机 | 数码 | 笔记本 | 台式机 | DIY硬件 | 外设 | 网络 | 数字家庭 | 评测 | 软件 | e时代 | 游戏 | 图片 | 壁纸 | 群乐 | 社区 | 博客 | 下载
软件频道>程序开发>JavaVBVCDelphiC/C++Web开发微软专栏移动数据库程序人生软件工程|产品中心下载什么是软件架构
您现在的位置: 天极网 > 开发频道 > Java实现各种排序 经典大放送
全文
群乐:Java

Java实现各种排序 经典大放送

2008-05-21 07:30 作者: 来自网络 出处: 天极网 责任编辑:nancy

  用Java语言实现的各种排序,包括插入排序、冒泡排序、选择排序、Shell排序、快速排序、归并排序、堆排序、SortUtil等。

  插入排序:

  


package org.rut.util.algorithm.support;
  import org.rut.util.algorithm.SortUtil;
  /**
  * @author treeroot
  * @since 2006-2-2
  * @version 1.0
  */
  public class InsertSort implements SortUtil.Sort
  {
  /* (non-Javadoc)
  * @see org.rut.util.algorithm.SortUtil.Sort#sort(int[])
  */
  public void sort(int[] data)
  {
  int temp;
  for(int i=1;i 
  for(int j=i;(j>0)&&(data[j] 
  SortUtil.swap(data,j,j-1);
  }
  }
  }
  }

 

  冒泡排序:

 


 package org.rut.util.algorithm.support;
  import org.rut.util.algorithm.SortUtil;
  /**
  * @author treeroot
  * @since 2006-2-2
  * @version 1.0
  */
  public class BubbleSort implements SortUtil.Sort
  {
  /* (non-Javadoc)
  * @see org.rut.util.algorithm.SortUtil.Sort#sort(int[])
  */
  public void sort(int[] data)
  {
  int temp;
  for(int i=0;i 
  for(int j=data.length-1;j>i;j--){
  if(data[j] 
  SortUtil.swap(data,j,j-1);
  }
  }
  }
  }
  }

 

  选择排序:

  


package org.rut.util.algorithm.support;
  import org.rut.util.algorithm.SortUtil;
  /**
  * @author treeroot
  * @since 2006-2-2
  * @version 1.0
  */
  public class SelectionSort implements SortUtil.Sort
  {
  /*
  * (non-Javadoc)
  *
  * @see org.rut.util.algorithm.SortUtil.Sort#sort(int[])
  */
  public void sort(int[] data) {
  int temp;
  for (int i = 0; i < data.length; i++) {
  int lowIndex = i;
  for (int j = data.length - 1; j > i; j--) {
  if (data[j] < data[lowIndex]) {
  lowIndex = j;
  }
  }
  SortUtil.swap(data,i,lowIndex);
  }
  }
  }

 

  Shell排序:

  


package org.rut.util.algorithm.support;
  import org.rut.util.algorithm.SortUtil;
  /**
  * @author treeroot
  * @since 2006-2-2
  * @version 1.0
  */
  public class ShellSort implements SortUtil.Sort{
  /* (non-Javadoc)
  * @see org.rut.util.algorithm.SortUtil.Sort#sort(int[])
  */
  public void sort(int[] data) {
  for(int i=data.length/2;i>2;i/=2){
  for(int j=0;j 
  insertSort(data,j,i);
  }
  }
  insertSort(data,0,1);
  }
  /**
  * @param data
  * @param j
  * @param i
  */
  private void insertSort(int[] data, int start, int inc) {
  int temp;
  for(int i=start+inc;i 
  for(int j=i;(j>=inc)&&(data[j] 
  SortUtil.swap(data,j,j-inc);
  }
  }
  }
  }

 

  快速排序:

  


package org.rut.util.algorithm.support;
  import org.rut.util.algorithm.SortUtil;
  /**
  * @author treeroot
  * @since 2006-2-2
  * @version 1.0
  */
  public class QuickSort implements SortUtil.Sort
  {
  /* (non-Javadoc)
  * @see org.rut.util.algorithm.SortUtil.Sort#sort(int[])
  */
  public void sort(int[] data)
  {
  quickSort(data,0,data.length-1);
  }
  private void quickSort(int[] data,int i,int j)
  {
  int pivotIndex=(i+j)/2;
  //swap
  SortUtil.swap(data,pivotIndex,j);
  int k=partition(data,i-1,j,data[j]);
  SortUtil.swap(data,k,j);
  if((k-i)>1) quickSort(data,i,k-1);
  if((j-k)>1) quickSort(data,k+1,j);
  }
  /**
  * @param data
  * @param i
  * @param j
  * @return
  */
  private int partition(int[] data, int l, int r,int pivot)
  {
  do
  {
  while(data[++l] while((r!=0)&&data[--r]>pivot);
  SortUtil.swap(data,l,r);
  }
  while(l SortUtil.swap(data,l,r);
  return l;
  }
  }

共3页。 1 2 3 :
网友关注
最新上市
编辑推荐
欢迎订阅天极网RSS聚合资讯:http://www.yesky.com/index.xml