A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 张聪珉 中级黑马   /  2013-8-9 19:17  /  1648 人查看  /  11 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

  1. public static void bubbleSort(int[] arr)
  2.         {
  3.                 for (int x=0; x<arr.length-1 ; x++ )
  4.                 {
  5.                         for(int y=0; y<arr.length-x-1; y++)//这里为什么arr.length-x之后还要再减去1啊,脑袋转不过来。。。。。
  6.                         {
  7.                                 if(arr[y]>arr[y+1])
  8.                                 {
  9.                                         swap(arr,y,y+1);
  10.                                 }
  11.                         }
  12.                 }
  13.         }

复制代码
问题在代码注释里

11 个回复

倒序浏览
本帖最后由 xuaner0719 于 2013-8-9 21:08 编辑

骚年好好看下面的图图,相信你会明白的。加油
  • j)vs (j+1).0角标的元素每次都要参与比较,故每循环一圈后j=0这时,循环比较后,最值出现在末位,故,第二次循环比较就相应地减少一位元素。此类推,就有减2,减3 因此,j<arr.length-x。当j得变量取值为6时,y+1=7就会造成角标越界,因此,只有当j+1=6,即j=5时,元素才有可比性。那么,j的取值范围为j<arr.length-x-1.


回复 使用道具 举报
你可以用假设法
假如这个数组有6个元素
x的范围就是0<=x<arr.length-1  即0-4也就是比较5次轮回
如果y的范围是0<=y<arr.length-x
当x=0的时候
y就是0-5
当y循环到5的时候
在if语句里面会出现arr[5]>arr[6]  但是arr数组只有6个元素  arr[6]是第七个
回复 使用道具 举报
防止数组角标越界
回复 使用道具 举报
arr[]的角标最大只能是arr.length-1。所以arr[y+1]中y+1<arr.length。即:y<arr.length-1。
每次比较都会忽略后面 x 个元素,因为后 x 个元素已经排好序。所以 y< arr.length-1-x。
这里必须还要减掉1就是这样来的。
回复 使用道具 举报
冒泡排序是这样的,因为最后一个元素不需要排。所以外循环要减一。对于内循环 减1。是因为在每一次比较时,也不用比arr.length次,而是少比一次。就好比我们三个人比身高,你说要比几次呢?显然要少比一次。所以要减1。这不是重点,重要的是哥们,你这样会报数组越界异常。在外层徨x=0的时。如果不减1。内层循环条件变为y<arr.length 而执行语句却有arr[y+1],角标y+1,当内层循环运行y自增到y刚好等于arr.length-1,此时y+1就等于arr.length.也就是下标等于数组的长度。显然不行。
回复 使用道具 举报
外层循环控制的是比较的轮数 内层循环控制的是每轮比较的次数 假如有7个元素 两两比较只需要比较6次就可以比较出一个最大的值
之后每轮比较的次数减一 因为上一轮比较出的最大值已经不用再参与比较了 这样说不知道楼主明白否?
楼主可以在纸上亲自一步一步画一画  相信会很容易就理解了的
需要注意的就是记住外层控制的是大的次数  而内层循环每次都会从0角标开始比较 所以一次比一次得少一个吧
仔细想想 不是很难理解的
回复 使用道具 举报
冒泡排序
        它的原理是数组中的相邻的两个元素进行比较,比较出现大小,根据是升序还是降序交换位置,
        比较完一次就可以把数组的最后一位就确定(最大值或最小值)这样最后一位就不用参与比较,
        这样依次就可以排出数组顺序,

/冒泡排序!
        public static void maoPao(int[] arr)
        {
                //外循环x控制的是比较的范围。角标不能自己跟自己比,所以想x<arr.length-1
                for (int x= 0;x<arr.length-1 ;x++ )
                {
                        //内循环时,相邻的角标比,比出大小,交换位置,比完一次后,最值就出现在了最后一个角标上,
                        //当第二次比较时y的范围就要缩小x,所以y<arr.length-x-1,每次的最值都会出现在被比较的最后一个角标上了
                        //以此类推,一个有序的数组就出来了,
                        for (int y=0;y<arr.length-x-1 ;y++ )
                        {
                                //比较相邻角标位上的值。
                                if (arr[y]>arr[y+1])
                                {
                                        //定义第三方变量,交换值。
                                        int temp = arr[y];
                                        arr[y]= arr[y+1];
                                        arr[y+1]=temp;
                                }
                        }
                }
        }
回复 使用道具 举报
可以简单举个例子,反着想一想,数组里只有三个数,排序···OK···
回复 使用道具 举报
这个是冒泡排序,如果你不-1,那么就会抛出数组下标越界异常(ArrayIndexOutofBoundexception)你可以看看。因为你始终都是和自己的下一在比较,如果不-1,那么到了最后一个数组下标不久越界了吗?所以必须要-1.
回复 使用道具 举报
public static void bubbleSort(int[] arr)
        {
                for (int x=0; x<arr.length-1 ; x++ )
                {
                        for(int y=0; y<arr.length-x-1; y++)//这里为什么arr.length-x之后还要再减去1啊,脑袋转不过来。。。。。
                                                                             //////减1是因为下面有y+1.如果不减1的话,这个数组算到最后那个角标的时候,再加一就会越界!
                        {
                                if(arr[y]>arr[y+1])
                                {
                                        swap(arr,y,y+1);
                                }
                        }
                }
        }
回复 使用道具 举报
简单点说 你可以这样理解  arr.length-1-x  首先length-1不用说了,肯定是防止角标越界,因为你冒泡是前一个跟后一个比较,不-1后面的y+1肯定越界,
其次-x就是说 每排序成功一个就需要把比较的次数-去1个,而x就是控制总的比较次数,所以-x
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马