文档章节

简单选择排序

Demens
 Demens
发布于 2017/05/19 10:19
字数 357
阅读 8
收藏 0

一、基本概念

      每趟从待排序的记录中选出关键字最小的记录,顺序放在已排序的记录序列末尾,直到全部排序结束为止。 

二、实现思路

  1. 从待排序序列中,找到关键字最小的元素;
  2. 如果最小元素不是待排序序列的第一个元素,将其和第一个元素互换;
  3. 从余下的 N - 1 个元素中,找出关键字最小的元素,重复(1)、(2)步,直到排序结束。

三、代码实现

public class SelectionSort {

    public static void selectionSort(int[] list){
        //需要遍历获得最小值的次数
        if (1>=list.length)return;
        for (int i=0;i<list.length-1;i++){
            int temp=0;
            int index=i;     //选择当前值为最小值索引
            for (int j=i+1;j<list.length;j++){
                if (list[index]>list[j]){
                    index=j;  //修改最小值索引
                }
            }
            
            temp=list[index];
            list[index]=list[i];
            list[i]=temp;
        }
    }
    public static void main(String[] args){
        int[] list={4,3,6,5,7,8,2,10,2,9};
        selectionSort(list);
        for (int num:list){
            System.out.print(num+" ");
        }
    }
}

四、时间复杂度

  • 简单选择排序的比较次数与序列的初始排序无关。 假设待排序的序列有 N 个元素,则比较次数总是N (N - 1) / 2。
  • 而移动次数与序列的初始排序有关。当序列正序时,移动次数最少,为 0.
  • 当序列反序时,移动次数最多,为3N (N - 1) /  2。
  • 所以,综合以上,简单排序的时间复杂度为 O(N2)。 

© 著作权归作者所有

共有 人打赏支持
上一篇: java插入排序
下一篇: 快速排序
Demens
粉丝 0
博文 11
码字总数 14760
作品 0
私信 提问

暂无文章

Flink-数据流编程模型

1、抽象等级 Flink提供了不同级别的抽象来开发流/批处理应用程序。 1) 低层级的抽象 最低层次的抽象仅仅提供有状态流。它通过Process函数嵌入到DataStream API中。它允许用户自由地处理来自一...

liwei2000
22分钟前
1
0
Java开发Swing实战JFrame和JTabbedPane容器的用法详细解析

概述: 项目是一个桌面程序,涉及标签和按钮组件、布局管理器组件、面板组件、列表框和下拉框组件等组件,以及Swing事件处理机制。 下面先从最基础的界面开始。 /** * @author: lishuai * @...

金铭鼎IT教育
27分钟前
7
0
flask 之旅

环境 为了正确地跑起来,你的应用需要依赖许多不同的软件。 就算是再怎么否认这一点的人,也无法否认至少需要依赖Flask本身。 你的应用的运行环境,在当你想要让它跑起来时,是至关重要的。 ...

hblt-j
27分钟前
5
0
easyui的上传文件

记录一下自己亲手操刀easyui的心得:不用不知道,一用就问题多,网上查资料,有用的真的太少了 ——————————————————正文 FileBox,还是不错的讲真,至少我去自己写就gaga了...

anlve
28分钟前
4
0
如何做好SQLite 使用质量检测,让事故消灭在摇篮里

本文由云+社区发表 SQLite 在移动端开发中广泛使用,其使用质量直接影响到产品的体验。 常见的 SQLite 质量监控一般都是依赖上线后反馈的机制,比如耗时监控或者用户反馈。这种方式问题是: ...

腾讯云加社区
31分钟前
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部