信息检索 
   

在线教师

在线教师

在线教师

在线教师

学习园地 [2008-04-02 03:39:23]
用Java语言实现的各种排序
用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 {
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;
public class BubbleSort implements SortUtil.Sort
{
public void sort(int[] data)
{
int temp;
for(int i=0;i for(int j=i+1;j if(data[i] SortUtil.swap(data,i,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 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;
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] while((r!=0)&&(data[--r]>pivot));
SortUtil.swap(data,l,r);
}
while(l 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 for(int j=i;(j>0)&&(data[j] SortUtil.swap(data,j,j-1);
}
}
}
}
 
 
版权所有:衡阳市天网计算机学校 (清华IT衡阳校区)
地址:衡阳市蒸湘南路32号清华IT楼 (房地局对面)   邮编:421000
全国免费电话:4006574119           电话:(0734)2456020、2456021 
传真:(0734)3123690                     
E_mail:hyqhit@hyqhit.com