当前位置: 代码迷 >> Java相关 >> java冒泡排序法
  详细解决方案

java冒泡排序法

热度:320   发布时间:2012-07-26 22:37:04.0
java冒泡排序法
/*冒泡法*/
class maopaodamo
{
    public static void main(String[] args)
    {
        int[] arr= new int[]{3,2,5,1,45,35,64,3};
        int i,x=0,j;
        for(j=0;j<7;j++)
        {
            for(i=0;i<7-j;i++)
            {
                if(arr[i]>arr[i+1])
                {
                    x=arr[i+1];
                    arr[i+1]=x;
                    x=arr[i];
                }
            }
        }
        for(j=0;j<7;j++)
        {
        System.out.print(arr[j]+";");
        }
        
    }
}
怎么排序不正确呢 问题 在哪啊 求指教  输不出正确的结果

[ 本帖最后由 wsws23 于 2012-7-26 22:43 编辑 ]
搜索更多相关的解决方案: java  public  

----------------解决方案--------------------------------------------------------
这个论坛 这么冷啊
----------------解决方案--------------------------------------------------------
 冒泡排序(BubbleSort)的基本概念是:依次比较相邻的两个数,将小数放在前面,大数放在后面。即在第一趟:首先比较第1个和第2个数,将小数放前,大数放后。然后比较第2个数和第3个数,将小数放前,大数放后,如此继续,直至比较最后两个数,将小数放前,大数放后。至此第一趟结束,将最大的数放到了最后。在第二趟:仍从第一对数开始比较(因为可能由于第2个数和第3个数的交换,使得第1个数不再小于第2个数),将小数放前,大数放后,一直比较到倒数第二个数(倒数第一的位置上已经是最大的),第二趟结束,在倒数第二的位置上得到一个新的最大数(其实在整个数列中是第二大的数)。如此下去,重复以上过程,直至最终完成排序。

public class maopao{
    public static void main(String[] args){
        int[] arr= new int[]{3,2,5,1,45,35,64,3};
        int i,x=0,j;
        for(j=0;j<7;j++){
            for(i=j;i<7;i++){
                if(arr[j]>arr[i]){
                    x=arr[j];
                    arr[j]=arr[i];
                    arr[i]=x;
                }
            }
        }
        
        for(j=0;j<7;j++){
        System.out.print(arr[j]+";");
        }
    }
}
先把冒泡的过程搞清楚吧~
----------------解决方案--------------------------------------------------------
楼主的循环并没有问题,只是if语句里面的交换写错了而已,无需看3楼的,楼主if里面只需要这样写就没有问题了
if(arr[i]>arr[i+1])
{
    x = arr[i+1];
    arr[i + 1] = arr[i];
    arr[i] = x;
}

[ 本帖最后由 yhlvht 于 2012-7-27 11:44 编辑 ]
----------------解决方案--------------------------------------------------------
对,是if语句写错了!!!

----------------解决方案--------------------------------------------------------
3楼正解
----------------解决方案--------------------------------------------------------
  相关解决方案