zoukankan      html  css  js  c++  java
  • 冒泡排序和直接插入排序和和快速排序和选择排序

    简单排序(学完了要及时复习,不然像没学一样,而且

    以后要花更多的时间)

    冒泡排序:小的数往上冒

    冒泡排序(BubbleSort)是重复地走访要排序的数列,

    一次比较两个元素,如果他们的顺序错误,就把他们就

    把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。

     

    原理:

    1.比较相邻的元素。如果第二个比第一个大,就交换他们两个。(小的在前)

    2.对每一对相邻元素作同样的工作,从第一对到结尾的

    最后一对。在这一点,最后的元素应该会是最大的数。

    3.针对所有的元素重复以上的步骤,出最后一个。

    4.持续每次对越来越少的元素重复上面的步骤,直到

    没有任何一对数字需要比较。

     

    时间复杂度:

    若文件的初始状态是正序的,一趟扫描即可完成排序。

    所需要的关键字比较次数C和记录和记录移动次数M

    均达到最小值:Cmin=n-1;

    Mmin=0;

    所以冒泡排序最好的时间复杂度为O(n)。

    public class BubbleSort{
        public static void sort(long[] arr){
            long tmp=0;
            for (int i=0;i<arr.length-1;i++) {
                //趟数,并让最小的于前
            for (int j=arr.length-1;j>i;j--) {
                    if (arr[j]<arr[j-1]) {
                        //进行交换
                        tmp=arr[j-1];
                        arr[j-1]=arr[j];
                        arr[j]=tmp;
                    }
                }    
            }
        }
    }
    
    public class TestSort1{
        public static void main(String[] args) {
            long[] arr=new long[5];
            arr[0]=34;
            arr[1]=23;
            arr[2]=2;
            arr[4]=1;
            arr[3]=-4;
            //如果没有赋值完的话,后面的直接补0
            System.out.print("[");
            for (long num:arr){
                //用法??
                System.out.print(num+" ");
    
            }
            System.out.print("]");
            System.out.println();
    
            BubbleSort.sort(arr);
            //排序后再打印 
    
            System.out.print("[");
            for(long num:arr){
                System.out.print(num+" ");
            }
            System.out.print("]");
            System.out.println();
    
        }
    }
    /*
    运行结果:
      i         j
    [34 23 2 -4 1 ]
    [-4 1 2 23 34 ]
    */

    //自己再去默写一次

     

    选择排序:

    选择最小的于前并交换位置,其余不变

    public class SelectionSort1{
        public static void sort(long[] arr){
            int k=0;
            long tmp=0;
            for (int i=0;i<arr.length-1;i++) {
                //趟数小于length-1,因为最后一个不用排序,就是最大的
                k=i;
                //最小的指向数,k去指向
                for (int j=i;j<arr.length;j++) {
                    //为什么是arr.length而不是length-1?length-1只能到length-1
                  //边界位置还是要思考思考!!最后再测试测试
                    if(arr[j]<arr[k]) {
                        k=j;
                    }
                }
                tmp=arr[i];
                arr[i]=arr[k];
                arr[k]=tmp;
            }
        }
    }
    
    public class TestSort2{
        public static void main(String[] args) {
            long[] arr=new long[5];
            arr[0]=34;
            arr[1]=23;
            arr[2]=2;
            arr[4]=1;
            arr[3]=-4;
            //如果没有赋值完的话,后面的直接补0
            System.out.print("[");
            for (long num:arr){
                //用法??
                System.out.print(num+" ");
    
            }
            System.out.print("]");
            System.out.println();
    
            SelectionSort1.sort(arr);
            //排序后再打印
    
            System.out.print("[");
            for(long num:arr){
                System.out.print(num+" ");
            }
            System.out.print("]");
            System.out.println();
    
        }
    }
    /*
    arr.length-1的循环结果
    [34 23 2 -4 1 ]
    [-4 2 23 34 1 ]
    arr.length的循环结果
    [34 23 2 -4 1 ]
    [-4 1 2 23 34 ]
    */

    直接插入排序:

    直接插入排序是一种简单的插入排序法,其基本思想是

    把待排序的记录按其关键码值的大小逐个插入到一个已经

    排好序的有序序列中,直到所有的记录插入完为止,得到

    一个新序列。

    例如,已知待排序的一组记录是

    60,71,49,11,24,3,66

    假设在排序过程中,前三个记录已经按关键码值递增

    的次序重新排序,构成一个有序序列:

    49,60,71

    将待排序记录中的第四个记录11插入尚需序列总,得到

    一个新的含4个记录的有序序列。

    1.设置监视r0,将待插入记录的值赋给r0;

    2.设置开始查找的位置j;

    3.在数组中进行搜索,搜索中将第j个记录后移,直到

    r0.key>=[j].key为止;

    4.将r0插入r[j+1]的位置上

     

     

    快速排序

    package Sort;
    
    import java.util.Arrays;
    
    public class QuickSort {
        public static void sort(int a[], int low, int hight) {
            int i, j, index;
            if (low > hight) {
                return;                  
            }
            i = low;
            j = hight;
            index = a[i]; // 用子表的第一个记录做基准
            while (i < j) { // 从表的两端交替向中间扫描
                while (i < j && a[j] >= index)
                    j--;
                if (i < j)
                    a[i++] = a[j];// 用比基准小的记录替换低位记录
                while (i < j && a[i] < index)
                    i++;
                if (i < j) // 用比基准大的记录替换高位记录
                    a[j--] = a[i];
            }
            a[i] = index;// 将基准数值替换回 a[i]
            sort(a, low, i - 1); // 对低子表进行递归排序  i - 1 ??
            sort(a, i + 1, hight); // 对高子表进行递归排序
    
        }
    
        public static void quickSort(int a[]) {
            sort(a, 0, a.length - 1);
        }
    
        public static void main(String[] args) {
    
            int a[] = { 49, 38, 65, 97, 76, 13, 27, 49 };
            quickSort(a);
            System.out.println(Arrays.toString(a));
        }
    }
    成年人的世界没有那么多的童话,也没有那么多的逆袭。
  • 相关阅读:
    横向技术分析C#、C++和Java优劣
    XML数据流主动服务系统的设计与实现
    ASP.NET 状态管理
    Oracle中如何从BasicFile迁移到SecureFile
    让UpdatePanel支持上传文件
    C#和Visual Basic渐行渐远之匿名类型
    wpf 移动变换
    WPF 样式学习总结
    临江仙
    wpf 动画效果
  • 原文地址:https://www.cnblogs.com/shijinglu2018/p/8449023.html
Copyright © 2011-2022 走看看