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

© 信仰年轻 中级黑马   /  2015-9-11 10:04  /  453 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

package 数组;
/**
* 对给定的数组进行排序
* {5,1,6,4,2,8,9}
* 思想:排序肯定要遍历数组,肯定是for循环(大圈套小圈)
  冒泡排序
    1、先从头角标相邻两个元素之间进行比较,将较大值存放在后一个元素中,然后再与后一个元素的进行比较,直至最大值存放到最后一个元素中。
    2、再重复1操作,每次计较次数减一,一圈比完后存放的较大元素不再参与比较。
* 冒泡排序是相邻的两个数进行比
  
*/

public class 数组冒泡排序
{
        public static void maoPao(int[]arr)
        {
                for(int x=0;x<arr.length;x++)
                {
                        for(int y=0;y<arr.length-x-1;y++)//-x:让每一次比较的元素减少 -1:避免角标越界
                        {
                                if(arr[y]>arr[y+1])//拿内循环0角标的数比内循环1角标的数,如果大于就换位置
                                {
                                        int temp=arr[y];
                                        arr[y]=arr[y+1];
                                        arr[y+1]=temp;
                                }
                        }
                }
        }
        public static void daYin(int[]arr)//打印输出函数
        {
                for(int x=0;x<arr.length;x++)
                {
                if(x!=arr.length-1)                       
                        System.out.print(arr[x]+",");                       
                else
                        System.out.println(arr[x]);
                }
        }                       
        public static void main(String[] args)
        {
                int [] arr={5,1,6,4,2,8,9};
                daYin(arr);//排序前
                maoPao(arr);//冒泡排序
                daYin(arr);//排序后
        }
}

1 个回复

倒序浏览
外循环x<arr.length-1,比较好。。因为等于x=arr.length-1已经可以不比较了。
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马