美文网首页
基础排序算法

基础排序算法

作者: 任教主来也 | 来源:发表于2017-02-07 15:14 被阅读30次

冒泡排序

  1. 排序原理:每次循环将末尾的最小的数往上冒,如果没有交换则跳出循环
  2. 跳出循环条件:如果一次循环没有交换说明后面的顺序是正确的,则不需要再排序可以跳出
public int[] sort1(int[] a) {
    for (int i = 1; i < a.length; i++) {
        boolean b = false;
        for (int j = a.length - 1; j >= i; j--) {
            if (a[j] < a[j - 1]) {
                int c = a[j];
                a[j] = a[j - 1];
                a[j - 1] = c;
                b = true;
            }
        }
        if (!b)
            break;

        System.out.println(Arrays.toString(a));
    }

    return a;
}

插入排序

  1. 排序原理:从第二个数开始,循环比较前一个数,直到最后一个数排序完成
  2. 内层循环中如果一次比较没有交换,则可以跳出内层循环,因为之前的都是排好的
public int[] sort(int[] a) {
    for (int i = 1; i < a.length; i++) {
        for (int j = i; j > 0; j--) {
            if (a[j] < a[j - 1]) {
                int c = a[j];
                a[j] = a[j - 1];
                a[j - 1] = c;
            } else {
                break;
            }
        }
        System.out.println(Arrays.toString(a));
    }

    return a;
}

二分法

二分法不是排序算法,但是是常用的基础算法

注意:传入的数组要求必须是排序后的

private int getIndex(int i, int[] a) {
    int index = -1;
    int low = 0, hight = a.length - 1;

    while (low <= hight) {

        int mid = (low + hight) / 2;
        if (a[mid] > i) {
            hight = mid - 1;
        } else if (a[mid] < i) {
            low = mid + 1;
        } else {
            return mid;
        }

    }

    return index;
}

相关文章

  • 开发者应该掌握的几种排序算法

    该篇文章主要介绍了算法基础以及几种常见的排序算法:选择排序、插入排序、冒泡排序、快速排序、堆排序。 一、算法基础 ...

  • 算法-排序算法总结

    排序类型总结 1 排序算法基础实现 2 排序算法应用 2.1 基础排序 2.2 计数排序应用 2.3 快排应用 2...

  • 算法与数据结构(二):排序篇-O(n^2)算法:选择 &

    排序基础 O(n^2)的算法虽然简单,但也实用!让我们从最简单的基础排序算法开始,打开我们的算法大门! 排序算法 ...

  • 基础排序算法总结

    排序算法分为内部排序和外部排序,而我们经常说的基础排序算法,都是内部排序算法。包括冒泡排序,选择排序,插入排序,快...

  • 排序算法

    概述 一般排序算法(以元素比较为基础) => 快速排序、归并排序、插入排序、冒泡排序、堆排序 特殊排序算法 => ...

  • 算法汇总

    关于算法: 基础技巧:分治、二分、贪心排序算法:快速排序、归并排序、计数排序搜索算法:回溯、递归、深度优先遍历,广...

  • 插入排序算法实现

    排序算法是最常见,最基础的算法,作者文集中记录了两种排序算法(插入排序,归并排序) 插入排序算法实现很简单直接,附...

  • 排序算法总结

    基础排序算法 基础排序算法相关接口和实现类 接口: 实现类(后续排序的父类): 1.选择排序 两层循环:内层循环进...

  • 算法与数据结构简介

    0x01 算法 基础技巧:分治、二分、贪心 排序算法:快速排序、归并排序、计数排序 搜索算法:回溯、递归、深度优先...

  • 数据结构与算法—排序(下)

    在上一篇排序算法中介绍了3中基础排序算法:选择排序,插入排序,希尔排序。接下来介绍的两钟排序算法《归并排序》和《快...

网友评论

      本文标题:基础排序算法

      本文链接:https://www.haomeiwen.com/subject/vxfmittx.html