各种内部排序java实现
来源:互联网 发布:厦门java培训 编辑:程序博客网 时间:2024/06/07 02:03
package sort;
public class SortTest {
public static void bubleSort(int[] a)
{
if(a==null)
{
return;
}
int length=a.length;
for(int i=0;i<length-1;i++)
{
for(int j=0;j<length-i-1;j++)
{
if(a[j]<a[j+1])
{
a[j]=a[j]^a[j+1];
a[j+1]=a[j]^a[j+1];
a[j]=a[j]^a[j+1];
}
}
out(a);
}
}
public static void selectSort(int[] a)
{
if(a==null)
{
return;
}
int length=a.length;
for(int i=0;i<length;i++)
{
for(int j=i+1;j<length;j++)
{
if(a[j]>a[i])
{
a[j]=a[j]^a[i];
a[i]=a[j]^a[i];
a[j]=a[j]^a[i];
}
}
out(a);
}
}
public static void insertSort(int[] a)
{
if(a==null)
{
return;
}
int length=a.length;
for(int i=0;i<length;i++)
{
int j=0;
while(a[i]>a[j]&&j<i)
{
j++;
}
int temp=a[i];
for(int n=i;n>j;n--)
{
a[n]=a[n-1];
}
a[j]=temp;
out(a);
}
}
public static void quick(int[] a,int s,int e)
{
int x=s;
if(s<e)
{
int point=a[s];
int m=s,n=e;
while(m<n)
{
while(m<n&&a[n]>=point)
{
n--;
}
if(m<n)
{
a[m++]=a[n];
}
while(m<n&&a[m]<=point)
{
m++;
}
if(m<n)
{
a[n--]=a[m];
}
}
a[m]=point;
out(a,s,e);
quick(a,s,m-1);
quick(a,m+1,e);
}
}
/***************************heap sort*********************************/
public static void heapJust(int[] a,int i,int len)
{
int left=2*i+1;
int right=2*i+2;
int largest=i;
while(left<len||right<len)
{
if(left<len&&a[largest]<a[left])
{
largest=left;
}
if(right<len&&a[largest]<a[right])
{
largest=right;
}
if(largest!=i)
{
a[largest]=a[largest]^a[i];
a[i]=a[largest]^a[i];
a[largest]=a[largest]^a[i];
i=largest;
left=2*i+1;
right=2*i+2;
}
else
{
break;
}
}
}
public static void buildHeap(int a[],int len)
{
int temp=len/2-1;
for(int i=temp;i>=0;i--)
{
heapJust(a,i,len);
}
}
public static void heapSort(int a[])
{
int len=a.length;
buildHeap(a,len);
out(a);
while(len>1)
{
swap(a,0,len-1);
heapJust(a,0,--len);
}
}
/***************************heap sort end*********************************/
public static void mergeSort(int[] a,int s,int e)
{
if(s==e)
{
return;
}
int mid=(s+e)/2;
mergeSort(a,s,mid);
mergeSort(a,mid+1,e);
int[] temp=new int[e-s+1];
int index=0;
int i=s,j=mid+1;
while(i<=mid&&j<=e)
{
if(a[i]<a[j])
{
temp[index++]=a[i++];
}
else
{
temp[index++]=a[j++];
}
}
while(i<=mid)
{
temp[index++]=a[i++];
}
while(j<=e)
{
temp[index++]=a[j++];
}
for(int ii=0;ii<temp.length;ii++)
{
a[s++]=temp[ii];
}
}
public static void out(int a[])
{
for(int i=0;i<a.length;i++)
{
System.out.print(a[i]+" ");
}
System.out.println();
}
public static void out(int a[],int s,int e)
{
for(int i=s;i<e;i++)
{
System.out.print(a[i]+" ");
}
System.out.println();
}
public static void swap(int[] a,int i,int j)
{
a[i]=a[i]^a[j];
a[j]=a[i]^a[j];
a[i]=a[i]^a[j];
}
public static void main(String[] args) {
// TODO Auto-generated method stub
int[] b={3,5,1};
int[] a={9,11,23,0,33,-23,143,234,654,4322};
out(a);
//bubleSort(a);
System.out.println();
//selectSort(a);
//insertSort(a);
//quick(a,0,a.length-1);
// heapSort(a);
mergeSort(a,0,a.length-1);
out(a);
}
}
public class SortTest {
public static void bubleSort(int[] a)
{
if(a==null)
{
return;
}
int length=a.length;
for(int i=0;i<length-1;i++)
{
for(int j=0;j<length-i-1;j++)
{
if(a[j]<a[j+1])
{
a[j]=a[j]^a[j+1];
a[j+1]=a[j]^a[j+1];
a[j]=a[j]^a[j+1];
}
}
out(a);
}
}
public static void selectSort(int[] a)
{
if(a==null)
{
return;
}
int length=a.length;
for(int i=0;i<length;i++)
{
for(int j=i+1;j<length;j++)
{
if(a[j]>a[i])
{
a[j]=a[j]^a[i];
a[i]=a[j]^a[i];
a[j]=a[j]^a[i];
}
}
out(a);
}
}
public static void insertSort(int[] a)
{
if(a==null)
{
return;
}
int length=a.length;
for(int i=0;i<length;i++)
{
int j=0;
while(a[i]>a[j]&&j<i)
{
j++;
}
int temp=a[i];
for(int n=i;n>j;n--)
{
a[n]=a[n-1];
}
a[j]=temp;
out(a);
}
}
public static void quick(int[] a,int s,int e)
{
int x=s;
if(s<e)
{
int point=a[s];
int m=s,n=e;
while(m<n)
{
while(m<n&&a[n]>=point)
{
n--;
}
if(m<n)
{
a[m++]=a[n];
}
while(m<n&&a[m]<=point)
{
m++;
}
if(m<n)
{
a[n--]=a[m];
}
}
a[m]=point;
out(a,s,e);
quick(a,s,m-1);
quick(a,m+1,e);
}
}
/***************************heap sort*********************************/
public static void heapJust(int[] a,int i,int len)
{
int left=2*i+1;
int right=2*i+2;
int largest=i;
while(left<len||right<len)
{
if(left<len&&a[largest]<a[left])
{
largest=left;
}
if(right<len&&a[largest]<a[right])
{
largest=right;
}
if(largest!=i)
{
a[largest]=a[largest]^a[i];
a[i]=a[largest]^a[i];
a[largest]=a[largest]^a[i];
i=largest;
left=2*i+1;
right=2*i+2;
}
else
{
break;
}
}
}
public static void buildHeap(int a[],int len)
{
int temp=len/2-1;
for(int i=temp;i>=0;i--)
{
heapJust(a,i,len);
}
}
public static void heapSort(int a[])
{
int len=a.length;
buildHeap(a,len);
out(a);
while(len>1)
{
swap(a,0,len-1);
heapJust(a,0,--len);
}
}
/***************************heap sort end*********************************/
public static void mergeSort(int[] a,int s,int e)
{
if(s==e)
{
return;
}
int mid=(s+e)/2;
mergeSort(a,s,mid);
mergeSort(a,mid+1,e);
int[] temp=new int[e-s+1];
int index=0;
int i=s,j=mid+1;
while(i<=mid&&j<=e)
{
if(a[i]<a[j])
{
temp[index++]=a[i++];
}
else
{
temp[index++]=a[j++];
}
}
while(i<=mid)
{
temp[index++]=a[i++];
}
while(j<=e)
{
temp[index++]=a[j++];
}
for(int ii=0;ii<temp.length;ii++)
{
a[s++]=temp[ii];
}
}
public static void out(int a[])
{
for(int i=0;i<a.length;i++)
{
System.out.print(a[i]+" ");
}
System.out.println();
}
public static void out(int a[],int s,int e)
{
for(int i=s;i<e;i++)
{
System.out.print(a[i]+" ");
}
System.out.println();
}
public static void swap(int[] a,int i,int j)
{
a[i]=a[i]^a[j];
a[j]=a[i]^a[j];
a[i]=a[i]^a[j];
}
public static void main(String[] args) {
// TODO Auto-generated method stub
int[] b={3,5,1};
int[] a={9,11,23,0,33,-23,143,234,654,4322};
out(a);
//bubleSort(a);
System.out.println();
//selectSort(a);
//insertSort(a);
//quick(a,0,a.length-1);
// heapSort(a);
mergeSort(a,0,a.length-1);
out(a);
}
}
0 0
- 各种内部排序java实现
- 内部排序 Java实现
- 内部各种排序算法实现代码
- 各种内部排序算法的实现
- Java实现各种排序
- Java实现各种排序
- java实现内部排序算法
- 内部排序(java实现)
- 各种排序算法(内部排序)及其实现
- 各种内部排序算法!
- 各种内部排序
- 各种内部排序
- 各种内部排序算法
- 各种内部排序算法的实现(c++实现)
- 各种排序算法java实现
- 各种排序算法java实现
- 各种排序算法java实现
- 各种排序算法Java实现
- muleStudio与Maven集成
- Hibernate高级查询方法
- Cocos2dx-3.2编译错误error C1083: 无法打开包括文件: “extensions/ExtensionMacros.h”: No such file or directory
- Android中ZXing简单使用
- Log4j配置很详细
- 各种内部排序java实现
- netbeans无法创建项目,提示:项目文件夹已是 NetBeans 项目文件夹 (可能仅在内存中)
- JS验证文本框不能输入纯空格。
- 关于软件设计的一点心得体会
- C语言一个双向链表的实现
- SQL Server中行列转换 Pivot UnPivot
- Hibernate 高级查询技巧——集合过滤与子查询
- X509证书编码格式和扩展名
- Android入门:向TextView添加滚动条(添加<ScrollView>标签)