黑马程序员技术交流社区

标题: 求教冒泡排序的问题 [打印本页]

作者: hf529270451    时间: 2015-11-11 20:07
标题: 求教冒泡排序的问题
public void BubbleSort(int[] arr) {
                for (int i = 0; i < arr.length; i++) {
                        for (int j = 0; j < arr.length-1-i; j++) {
                                if(arr[j] > arr[j+1]) {
                                        jiaohuan(arr, j);
                                }
                        }
                }
        }
内层循环为什么是length-1-i啊   每次循环不是因该是从int j = 0+ i 开始吗  
作者: 萧未然    时间: 2015-11-11 20:15
本帖最后由 萧未然 于 2015-11-11 20:21 编辑

首先,冒泡排序原理是(如上从小到大排):每一个外层元素跟内层的未确定大小比较,只要冒出较大数就挖出来,往后排而为什么-1?因为内层循环中有下标j+1的比较,第一个:不-1的话,当i=0时,内层比较中就越界了呀
再:当i每次跟内层元素j比较完后都得到了从后往前的最大值,所以当外层i++时,就可以比较除了这个最大值下标的其他值啦,而i每次自增1,
通过内层就慢慢的取出了从小到大的序列了
建议画图

作者: mandoooo    时间: 2015-11-11 20:24
本帖最后由 mandoooo 于 2015-11-11 20:37 编辑

第一个for写错了
for (int i = 0; i < arr.length-1; i++) {      //必须要减1 因为最后一圈剩了一个数,所以他没必要比了。
第二个for的arr.length-1-i里减-1的原因是
for(arr[j]>arr[j+1])的条件里
例如你的数组长度是 4的话
arr[1]比arr[2]
arr[2]比arr[3]
arr[3]比arr[4]        但是没有arr[4]这个元素,因为数组的总长度是4,他的最后元素是arr[3],所以要减1才行






欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2