当前位置: 代码迷 >> J2SE >> 直接插入排序小疑点
  详细解决方案

直接插入排序小疑点

热度:188   发布时间:2016-04-24 01:37:16.0
直接插入排序小问题
刚开始学习java,做了个排序的练习可发现有这么一个问题,跪求解答。为什么把temp换成a[i]之后就不对了?代码如下
public static void main(String[] args) {
// TODO Auto-generated method stub
int a[]={4,3,2,5,1};
int temp=0;
int j=0;
for(int i=1;i<a.length;i++)
{
if(a[i]<a[i-1])
{ temp=a[i];

for( j=i-1;j>=0&&a[j]>temp;j--)//这里比较的是temp而不是a[i]区别是有可为什么呢?

{
a[j+1]=a[j];
}
a[j+1]=temp;
}
}
for(int i=0;i<a.length;i++)
{
System.out.println(a[i]);
}
}

------解决方案--------------------
还是插入排序啊...你是怎么理解这个算法的呢,我的代码在下面:
Java code
public class Sorts {    public static void main(String[] args) {        // TODO Auto-generated method stub        int a[]={4,3,2,5,1};        int temp=0;        for(int i=0;i<a.length;i++){            for(int j=i;j>0&&(a[j]<a[j-1]);j--){                temp=a[j];                a[j]=a[j-1];                a[j-1]=temp;            }        }        for(int i:a){        System.out.print(i+" ");        }    }}
  相关解决方案