前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >简单排序

简单排序

作者头像
悠扬前奏
发布2019-05-31 16:08:56
3070
发布2019-05-31 16:08:56
举报

简单排序(Java实现)。

冒泡排序

原理

  1. 比较相邻元素,如果前者比后者大,交换
  2. 对所有相邻元素重复
  3. 对除了最后一个的所有元素重复2

复杂度

最好情况:O(n) 平均时间复杂度:O(n^2)

代码

代码语言:javascript
复制
public static void bubbleSort(int[] a){
    for(int outer = a.length - 1; outer > 1; outer--)
        for(int inner = 0; inner < outer ;inner++)
            if(a[inner] > a[inner + 1])
                swap(a, inner, inner+1);
}

选择排序

原理

每次选出最小的元素放到开始位置。

复杂度

时间复杂度 O(n^2) 但是交换次数比冒泡排序少

代码

代码语言:javascript
复制
public static void selectSort(int[] a){
    int min;
    for(int i = 0; i < a.length - 1; i++){
        min = i;
        for(int j = i + 1; j < a.length; j++)
            if(a[j] < a[min]) min = j;
        swap(a, i, min);
    }
}

插入排序

原理

在局部有序的数字中插入被标记的值。

复杂度

时间复杂度为O(n^2) 但是一般情况下比冒泡排序快一倍,比选择排序也快一点。

代码

代码语言:javascript
复制
public static void insertSort(int[] a){
    for(int i = 1; i < a.length; i++){
        int j = i, temp = a[i];
        while(j > 0 && a[j - 1] >= temp){
            a[j] = a[j - 1];j--;
        }
        a[j] = temp;
    }
}

三种排序的比较

选择排序降低了交换次数,但是比较次数仍然很多,当数据量比较少,或者基本上有序的时候,使用选择排序。 对于其他情况,应该选择插入排序。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017.07.14 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 冒泡排序
    • 原理
      • 复杂度
        • 代码
        • 选择排序
          • 原理
            • 复杂度
              • 代码
              • 插入排序
                • 原理
                  • 复杂度
                    • 代码
                    • 三种排序的比较
                    领券
                    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档