日期:2014-05-20  浏览次数:20738 次

直接插入排序小问题
刚开始学习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+" ");
        }
    }
}