回到首页>> 学习园地

用Java语言实现的各种排序

2006.7.8
  

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

插入排序法
package org.rut.util.algorithm.support;
import org.rut.util.algorithm.SortUtil;
public class InsertSort implements SortUtil.Sort
{
    public void sort(int[] data)
    {
        int temp;
        for(int i=1;i<DATA.LENGTH;I++){
            for(int j=i;(j>0)&&(data[j]<DATA[J-1]);J--){
                SortUtil.swap(data,j,j-1);
            }
        }
    }
}

冒泡排序法
package org.rut.util.algorithm.support;
import org.rut.util.algorithm.SortUtil;
public class BubbleSort implements SortUtil.Sort
{
    public void sort(int[] data)
    {
        int temp;
        for(int i=0;i<DATA.LENGTH-1;I++){
            for(int j=i+1;j<DATA.LENGTH;J++{
                 if(data[i]<DATA[J]{
            }
        }
    }
}

快速排序
package org.rut.util.algorithm.support;
import org.rut.util.algorithm.SortUtil;
public class BubbleSort implements SortUtil.Sort{
public void sort(int[] data) {
    int temp;
    for(int i=0;i<DATA.LENGTH;I++{
        for(int j=data.length-1;j>i;j--){
            if(data[j]<DATA[J-1]){
                SortUtil.swap(data,j,j-1);
             }
        }
    }
}
}

改进后的快速排序
package org.rut.util.algorithm.support;
import org.rut.util.algorithm.SortUtil;
public class ImprovedQuickSort implements SortUtil.Sort {
private static int MAX_STACK_SIZE=4096;
private static int THRESHOLD=10;
public void sort(int[] data) {
    int[] stack=new int[MAX_STACK_SIZE];
    int top=-1;
    int pivot;
    int pivotIndex,l,r;
    stack[++top]=0;
    stack[++top]=data.length-1;
    while(top>0){
        int j=stack[top--];
        int i=stack[top--];
        pivotIndex=(i+j)/2;
        pivot=data[pivotIndex];
        SortUtil.swap(data,pivotIndex,j);
        l=i-1;
        r=j;
        do{
            while(data[++l]<PIVOT);
             while((r!=0)&&(data[--r]>pivot));
            SortUtil.swap(data,l,r);
           }while(l<R);
           SortUtil.swap(data,l,r);
           SortUtil.swap(data,l,j);
           if((l-i)>THRESHOLD){
                stack[++top]=i;
                stack[++top]=l-1;
           }
           if((j-l)>THRESHOLD){
                stack[++top]=l+1;
            stack[++top]=j;
            }
        }
        insertSort(data);
     }
     private void insertSort(int[] data) {
          int temp;
          for(int i=1;i<DATA.LENGTH;I++){
             for(int j=i;(j>0)&&(data[j]<DATA[J-1];J--){
             SortUtil.swap(data,j,j-1);                 }
          }
     }
}

网站导航  使用帮助  招聘信息  联系我们  中心地图  在线留言
   
  ©版权所有2004 岳阳海纳软件教育培训中心
地址:岳阳市南湖大道48号银都大厦北门二楼(国际大厦对面)
电话:0730-8236899 8236799
QQ : 119563493 
网址:http://www.yy-accp.com
邮箱:reny6568@126.com