一、选择排序的介绍

  选择排序(Selection sort)是一种简单直观的排序算法。首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。

  选择排序的主要优点与数据移动有关。如果某个元素位于正确的最终位置上,则它不会被移动。选择排序每次交换一对元素,它们当中至少有一个将被移到其最终位置上,因此对n个元素的表进行排序总共进行至多n-1次交换。在所有的完全依靠交换去移动元素的排序方法中,选择排序属于非常好的一种。

二、选择排序的原理

  1. 未排序序列中找到最小(大)元素,存放到排序序列的起始位置
  2. 再从剩余未排序元素中继续寻找最小(大)元素
  3. 然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。

三、选择排序的图解

 

四、选择排序总结

  1. 有N个数据,需要从未排序区挑选N-1次数据放在已排序区队尾
  2. 每次从未排序区中挑选的数据要放在已排序的队尾

五、选择排序的python代码实现

# 定义选择排序函数
def selection_sort(list):
# 计算需要排序的列表元素个数
N = len(list)
# 需要N-1次选择操作
for i in range(N-1):
# 记录最小值的小标
minNum_index = i
# 未排序区域从i+1到末尾N处,属于未排序区,在未排序区在选出最小值处
for j in range(i+1,N):
# 比较大小
if list[minNum_index]>list[j]:
#交换
temp = list[minNum_index]
list[minNum_index] = list[j]
list[j] = temp # 创建一个列表
numList = [19,2,13,8,34,25,7] print("排序前:%s"%numList)
# 调用选择排序
selection_sort(numList)
print("排序后:%s"%numList)

运行结果为:

排序前:[19, 2, 13, 8, 34, 25, 7]
排序后:[2, 7, 8, 13, 19, 25, 34]

六、选择排序的C语言代码实现

版本一

#include <stdio.h>
//定义选择排序函数
void selection_sort(int array[],int arrayLenght)
{
// 需要N-1次选择操作
for (int i=; i<arrayLenght-; i++)
{
// 记录最小值的下标
int minNum_index = i;
// 未排序区域从i+1到末尾N处,属于未排序区,在未排序区再选出最小值处
for (int j = i+; j<arrayLenght; j++)
{
// 比较大小
if (array[minNum_index]>array[j])
{
// 交换
int temp = array[minNum_index];
array[minNum_index] = array[j];
array[j] = temp;
}
}
}
} int main(int argc, const char * argv[]) { // 选择排序函数声明
void selection_sort(int array[],int arrayLenght);
// 创建数组
int numArray[] = {,,,,,,};
// 调用排序
selection_sort(numArray, );
// 验证
for (int i =; i<; i++)
{
printf("%d ",numArray[i]);
} return ;
}

运行结果为:

      

版本二

#include <stdio.h>
//定义选择排序函数
void selection_sort1(int array[],int arrayLenght)
{
// 需要N-1次选择操作
for (int i=; i<arrayLenght-; i++)
{
// 记录最小值的下标
int minNum_index = i;
// 未排序区域从i+1到末尾N处,属于未排序区,在未排序区再选出最小值处
for (int j = i+; j<arrayLenght; j++)
{
// 比较大小
if (array[minNum_index]>array[j])
{
minNum_index = j;
}
}
if (minNum_index != i)
{
int temp = array[i];
array[i] = array[minNum_index];
array[minNum_index] = temp; }
}
} int main(int argc, const char * argv[]) { // 选择排序函数声明
void selection_sort1(int array[],int arrayLenght);
// 创建数组
int numArray[] = {,,,,,,};
// 调用排序
selection_sort1(numArray, );
// 验证
for (int i =; i<; i++)
{
printf("%d ",numArray[i]);
} return ;
}

运行结果为:

      

七、选择排序的时间复杂度

  • 最优时间复杂度:O(n2)
  • 最坏时间复杂度:O(n2)

八、选择排序的稳定性

  选择排序是给每个位置选择当前元素最小的,比如给第一个位置选择最小的,在剩余元素里面给第二个元素选择第二小的,依次类推,直到第n-1个元素,第n个元素不用选择了,因为只剩下它一个最大的元素了。那么,在一趟选择,如果一个元素比当前元素小,而该小的元素又出现在一个和当前元素相等的元素后面,那么交换后稳定性就被破坏了。比较拗口,举个例子,序列5 8 5 2 9,我们知道第一遍选择第1个元素5会和2交换,那么原序列中两个5的相对前后顺序就被破坏了,所以选择排序是一个不稳定的排序算法。

python算法与数据结构-选择排序算法(33)的更多相关文章

  1. 冒泡排序算法和简单选择排序算法的js实现

    之前已经介绍过冒泡排序算法和简单选择排序算法和原理,现在有Js实现. 冒泡排序算法 let dat=[5, 8, 10, 3, 2, 18, 17, 9]; function bubbleSort(d ...

  2. python基础:冒泡和选择排序算法实现

    冒泡排序和选择排序   首先引用一下百度百科对于冒泡算法的定义:   冒泡排序算法的原理如下: 比较相邻的元素.如果第一个比第二个大,就交换他们两个. 对每一对相邻元素做同样的工作,从开始第一对到结尾 ...

  3. python算法与数据结构-希尔排序算法(35)

    一.希尔排序的介绍 希尔排序(Shell Sort)是插入排序的一种.也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本.希尔排序是非稳定排序算法. 希尔排序是把记录按下标的一定增量分组,对每 ...

  4. 【排序算法】直接选择排序算法 Java实现

    基本思想 直接选择排序是从无序区选一个最小的元素直接放到有序区的最后. 初始状态:无序区为a[1...n],有序区为空. 第一次排序:在无序区a[1...n]中选出最小的记录a[k],将它与有序区的第 ...

  5. 排序算法系列:选择排序算法JAVA版(靠谱、清晰、真实、可用、不罗嗦版)

    在网上搜索算法的博客,发现一个比较悲剧的现象非常普遍: 原理讲不清,混乱 啰嗦 图和文对不上 不可用,甚至代码还出错 我总结一个清晰不罗嗦版: 原理: 从数组头元素索引i开始,寻找后面最小的值(比i位 ...

  6. 算法学习之选择排序算法的python实现

    ——参考自<算法图解> def findSmallest(arr): # 假设第一个元素最小 smallest = arr[0] smallest_index = 0 for i in r ...

  7. 「浙江理工大学ACM入队200题系列」问题 A: 零基础学C/C++34—— 3个数比较大小(冒泡排序与选择排序算法)

    本题是浙江理工大学ACM入队200题第四套中的A题,同时给出了冒泡排序和选择排序算法 我们先来看一下这题的题面. 由于是比较靠前的题目,这里插一句.各位新ACMer朋友们,请一定要养成仔细耐心看题的习 ...

  8. 《算法4》2.1 - 选择排序算法(Selection Sort), Python实现

    选择排序算法(Selection Sort)是排序算法的一种初级算法.虽然比较简单,但是基础,理解了有助于后面学习更高深算法,勿以勿小而不为. 排序算法的语言描述: 给定一组物体,根据他们的某种可量化 ...

  9. python选择排序算法总结

    选择排序算法: a=[6,5,4,3,2,1] 算法思路: 第一步:在列表的第一个位置存放此队列的最小值 声明一个变量min_index等于列表的第一个坐标值0 从第一个位置0坐标开始,和它后边所有的 ...

随机推荐

  1. mac自带ssh在哪

    打开Finder,前往> 前往文件夹,输入 ~/.ssh 回车就到ssh目录了. 点击Mac顶部菜单-->“苹果”图标-->最近使用的项目-->终端--输入 open ~/.s ...

  2. react中使用typescript时,error: Property 'setState' does not exist on type 'Home'

    问题描述: 我在react中用typescript时,定义一个Home组件,然后在组件里用setState时会有这样一个报错:(如图)Property 'setState' does not exis ...

  3. win10无法安装软件解决

    https://www.windowscentral.com/how-fix-network-resource-unavailable-install-error-windows-10

  4. Linux05 文件或目录的权限(ls、lsattr、chattr、chmod、chown、chgrp、file)

    一.查看文件或目录的权限:ls -al  文件名/目录名 keshengtao@LAPTOP-F9AFU4OK:~$ ls -al total drwxr-xr-x keshengtao keshen ...

  5. 函数的练习3——python编程从入门到实践

    8-12 三明治: 编写一个函数,它接受顾客要在三明治中添加的一系列食材.这个函数只有一个参数(它收集函数调用中提供的所有食材),并打印一条消息,对顾客点的三明治进行概述.调用这个函数三次,每次提供不 ...

  6. python列表生成式、键盘输入及类型转换、字符串翻转、字母大小写、数组广播、循环语句等基础问题

    Python知识总结 1.列表生成式 ​ 在实际开发过程中,当需要获取一个连续列表时,可直接使用range(3,10),但是如果获取该列表中每个数据的平方时,通常可以通过for循环来解决这个问题,如下 ...

  7. PAT(B) 1045 快速排序(C)

    题目链接:1045 快速排序 (25 point(s)) 参考博客:1045 快速排序 (25 point(s))繁星蓝雨 题目描述 著名的快速排序算法里有一个经典的划分过程:我们通常采用某种方法取一 ...

  8. 保研经验帖----江西师范大学 to 华中科技大学

    呼,距离拿到华科cs的offer也有一段时间,有好几次准备动手写这篇经验帖,但就是理不清自己想表达什么,今早起来状态还不错,洗漱的时候思路居然通透了,哈哈哈~ 一.基本情况 先简单介绍笔者的一些基本情 ...

  9. java之struts2之类型转换

    在使用servlet开发中,表单中提交的数据到servlet后都是字符串类型,需要程序员手动进行类型转换. 但是到struts2后,基本数据类型struts2都可以转换.但是如果是自定义类型,stru ...

  10. node.js开发 npm包管理工具

    npm介绍 说明:npm(node package manager)是nodejs的包管理器,用于node插件管理(包括安装.卸载.管理依赖等) 使用npm安装插件:命令提示符执行npm instal ...