首页产品库评测行情新闻|手机数码笔记本台式机DIY硬件数字家庭数码相机办公外设|软件下载游戏开发|社区

更多

数码相机
MP4
LCD
机箱
音箱

软件资讯设计 工具 系统 开发 安全 办公 陶吧 IT教育 Vista频道 | 下载中心酷我音乐盒 腾讯QQ
天极网 > 开发频道>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页。 123下一页
进入 最权威的Windows 7论坛 查看网友讨论

软件频道最新更新

热点推荐

IT嘉年华

编辑推荐

软件下载

热门
推荐

网友关注

软件
资料
游戏

装机推荐

文章排行

本周
本月
最新更新
天极服务|关于我们|About us|网站律师|RSS订阅|友情合作|加入我们|天极动态|网站地图|意见反馈|MSN/QQ上看天极
Copyright (C) 1999-2012 Yesky.com, All Rights Reserved 版权所有 天极网络