zoukankan      html  css  js  c++  java
  • 冒泡,简单选择,直接插入排序(Java版)

    冒泡。简单选择,直接插入这三种排序都是简单排序。

    工具类

    package Utils;
    
    import java.util.Arrays;
    
    public class SortUtils {
        public static void swap(int[] a,int i,int j){
            int temp = a[i];
            a[i] = a[j];
            a[j] = temp;
        }
    
        public static void printString(int[] a){
    
            System.out.println(Arrays.toString(a));
        }
    }

    冒泡排序

    package BubbleSort;
    import java.util.Arrays;
    import Utils.SortUtils;
    
    public class Demo02 {
    
        public static void bubbleSort(int[] a){
            int len = a.length;
            boolean flag = true;
            for(int i=0; i<len-1 && flag; i++){
                flag = false;//如果无须交换
                for(int j=0; j< len-1-i; j++)
                {
                    if(a[j+1]<a[j]){
                        flag = true;//交换了
                        SortUtils.swap(a,j+1,j);
                    }   
                }
            }   
        }
    
    
        public static void main(String[] args) {
    
            int[] a = {2,3,5,4,1,6,9,8,7};      
            bubbleSort(a);
            SortUtils.printString(a);
    
        }
    }

    简单选择排序

    package SimpleSort;
    import java.util.Arrays;
    import Utils.SortUtils;
    
    public class Demo {
    
        public static void simpleSort(int[] arr){
            int min;
            for (int i = 0; i < arr.length; i++) {
                min = i;//如果第一个数据为最小的数据
    
                for (int j = i+1; j < arr.length; j++) {
                    if(arr[min]>arr[j]){
                        min = j;
                    }
                }
                if(i!=min){
                    SortUtils.swap(arr, min, i);
                }
            }
        }
    
        public static void main(String[] args) {
            int[] a = {2,3,5,4,1,6,9,8,7};  
            simpleSort(a);
            SortUtils.printString(a);
        }
    }


    直接插入排序

    package InsertSort;
    import Utils.SortUtils;
    
    public class Demo {
        public static void insertSort(int[] a){
            int temp,j;
            for (int i = 0; i < a.length-1; i++) {
                if(a[i]>a[i+1]){//后一个数据小于前一个数据
                    temp = a[i+1];//放入缓存区
                    for (j = i; j>=0&&a[j]>temp; j--) {
                        a[j+1] = a[j];//往后移动
                    }
                    //由于前面减一之后做的推断,所以这里加一
                    a[j+1] = temp;
                }
            }
        }
    
        public static void main(String[] args) {
            int[] a = {2,3,5,4,1,6,9,8,7};  
            insertSort(a);
            SortUtils.printString(a);
        }
    }



    比較三种排序



  • 相关阅读:
    未在本地计算机上注册“Microsoft.Jet.OleDb.4.0”提供程序
    GridView选中行变色
    GridView 添加/删除行
    Session、Cookie、Application、ViewState和Cache 这四者的区别
    后台动态给textbox的字体颜色赋值
    JS来判断文本框内容改变事件
    gridview JS控件赋值后如何取值
    c#如何把8位字符串转换成日期格式
    从今天起,热爱生活
    杂得得杂
  • 原文地址:https://www.cnblogs.com/liguangsunls/p/7146194.html
Copyright © 2011-2022 走看看