java数组排序基算法

1、冒泡排序
算法基本思想
冒泡排序的基本思想是对比相邻的元素值,如果满足条件就交换元素值,把较小的元素移动到数组前面,把大的元素移动到数组后面(也就是互换两个元素的位子),这样较小的元素就像气泡一样从底部上升到顶部。

public class Bubbling {
    public static void main(String[] args) {
        int[] arr = {12,6,35,16,74};
        bubbingSort(arr);
    }

    public static void bubbingSort(int[] arrP){
        for(int i = 0;i < arrP.length;i++){
            for(int j = 0;j < arrP.length - i -1;j++ ){
                if(arrP[j] > arrP[j+1]){
                    int temp = arrP[j];
                    arrP[j] = arrP[j+1];
                    arrP[j+1] = temp;
                }
            }
        }
        for(int i = 0;i < arrP.length;i++ ){
            System.out.println(arrP[i]);
        }
    }
}

2、选择排序法
算法基本思想
将指定排序位置与其他数组元素分别对比,如果满足条件就交换元素值,注意这里区别冒泡排序,不是交换相邻元素,而是把满足条件的元素与指定的排序位置交换(如从最后一个元素开始排序),这样排序好的位置逐渐扩大,最后整个数组都成为已排序好的格式。

public class Select {
    public static void main(String[] args) {
        int[] arr = {12,6,35,16,74};
        selectSort(arr);
    }
    public static void selectSort(int[] arrP){
        int index ;
        for(int i = 1;i < arrP.length;i++ ){
            index = 0;
            for(int j = 1;j <= arrP.length - i;j++ ){
                if(arrP[j] > arrP[index]){
                    index = j;
                }
            }
            int temp = arrP[arrP.length-i];
            arrP[arrP.length-i] = arrP[index];
            arrP[index] = temp;
        }
        for(int i = 0;i < arrP.length;i++ ){
            System.out.println(arrP[i]);
        }
    }

}

选择排序法性能比冒泡排序效率更高些,因为选择排序在对换上比冒泡排序要少。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值