首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

排序算法Java代码实现(一)—— 选择排序

以下几篇随笔都是记录我实现八大排序代码,主要是贴出代码吧,讲解什么都没有,主要是为了方便我自己复习,哈哈,如果看不明白,也不要说我坑哦!...本片分为两部分代码: 常用方法封装 排序算法里需要频繁使用 交换数组中两数位置 操作,另外,为了方便我打印数组查看结果,我封装一个 ArrayBase.java基类,用来实现swap...方法和printArray方法; 选择排序算法 (一)ArrayBase.java /** * */ package com.cherish.SortingAlgorithm; /** * @...(代码继承ArrayBase基类,swap和printArray方法直接用) 排序思想: 从数组中选择最小元素,将它与数组第一个元素交换位置。...再从数组剩下元素中选择出最小元素,将它与数组第二个元素交换位置。 不断进行这样操作,直到将整个数组排序

70640
您找到你想要的搜索结果了吗?
是的
没有找到

算法-排序算法-选择排序

/** * 排序算法-选择排序 * 选择排序(Selection Sort)算法也是比较简单排序算法,其思路比较直观。选择排序算法在每一步中选取最小值来重新排列,从而达到排序目的。...* 选择排序算法通过选择和交换来实现排序,其排序流程如下: * (1)首先从原始数组中选择最小1个数据,将其和位于第1个位置数据交换。...* (2)接着从剩下n-1个数据中选择次小1个数据,将其和第2个位置数据交换。 * (3)然后不断重复上述过程,直到最后两个数据完成交换。至此,便完成了对原始数组从小到大排序。...* * 选择排序算法在对n个数据进行排序时,无论原数据有无顺序,都需要进行n-1步中间排序。 * 这种排序方法思路很简单直观,但是缺点是执行步骤稍长,效率不高。...size; i++) { ints[i] = (int)(Math.random() * 100 ); } System.out.println("排序数组

1.5K30

排序算法-选择排序

算法简介 选择排序就是找到数组中最小元素将其和数组第一个元素交换位置,然后在剩下元素中找到最小元素并将其与数组第二个元素进行交换,以此类推,直至整个数组排序结束。...算法描述 找到数组中最小元素并将其和数组第一个元素交换位置 在剩下元素中找到最小元素并将其与数组第二个元素交换,直至整个数组排序 ?...代码实现 /** * 选择 * * @param array */ private static void selectionSort(int[]...由于每次都是选取未排序序列R中最小元素 a 与 R 中第一个元素交换,很可能破坏了元素间相对位置,因此选择排序是不稳定。...排序算法 平均时间复杂度 最好情况 最坏情况 空间复杂度 稳定性 选择排序 \(O(n^2)\) \(O(n^2)\) \(O(n^2)\) \(O(1)\) 不稳定

1.6K40

排序算法---选择排序

排序是我们学习算法过程中重要且基础一环,例如对下面的排序问题,我们应该怎么做呢?...选择排序思想和实现思路 提到排序问题,很容易想到思路就是找出来所有数据中最大(或最小)元素,放在一个新列表第一位,然后再在剩下元素中找出最大(或最小)元素,放在新列表第二位,以此类推......这就是选择排序(selection sort)算法思想。 上图就是选择排序算法思想,但一个算法实现往往不能通过一个简单思想就搞定(这就是思想与现实距离,哈哈~)。...选择算法实现并不会新建一个空白列表(因为这样太奢侈了),而是直接在原列表上进行操作:首先先从列表中找出最大(或者最小)元素,将其与列表中第一个元素互换位置,然后再从剩余元素中挑选出最大(或者最小)...具体实施步骤如下: 算法实现 接下来我们看一下其具体算法实现: #include #include using namespace std; struct

67410

算法渣-排序-选择排序

没有一身好内功,招式再多都是空;算法绝对是防身必备,面试时更是不可或缺;跟着算法渣一起从零学算法 定义 选择排序(Selection sort)是一种简单直观排序算法。...以此类推,直到全部待排序数据元素排完。 选择排序是不稳定排序方法。...算法 n个记录文件直接选择排序可经过n-1趟直接选择排序得到有序结果: 初始状态:无序区为R[1..n],有序区为空 第1趟排序 在无序区R[1..n]中选出关键字最小记录R[k],将它与无序区第...O(n);而选择排序不论如何,永远都是O(n^2) 插入排序是边读边排,每当读入一个新数时,目前数组一定是排好序。...而选择排序不同,它必须是读完所有的数据之后才能开始排序。 那么选择排序缺点就是,万一数据量很大,比方说一百万个,光读就慢了,还要排序,那就更慢了。

77920

选择排序算法

冒泡排序算法算法与数据结构中最基础排序算法。学会这个算法是有必要,在2010年左右时候,很多时候面试都会冒泡排序算法。那时候IT行业没现在这么卷,大部分都考察一下冒泡排序就OK了。...现在去面试不问个leetcodehard难度级别题都不过瘾。那现在有必须在学习冒泡排序吗?当然有必要,基础算法必须掌握,体现你技术热情,对走技术路线是有绝对帮助。...冒泡排序就是排队一样,矮排前面,高排后面。  刚开始是乱序,那就从第一个开始调整,把最高排到后面。排完这个之后,这个位置就被占用。 那再从第一个开始,再找出一个最高放在倒数第二个位置。...发现没有,每个最高放在最后,然后缩小数组范围,再找出一个高放在最后。 关键点:  每次都从第一个开始,写代码时候要注意。 一趟比较后,最后那个位置放最大数。...下面我们一下代码实现: def sel_sort(elements) : n = len(elements) for i in range(n): index = i

78530

排序算法】冒泡排序选择排序

冒泡排序 思想 冒泡排序,又被称为气泡排序或泡沫排序。...图片演示 代码实现 void bubble_sort(int* arr,int sz) { int i = 0; int flag = 1; for (i = 0; i < sz-1; i++)...O(N^2) 空间复杂度:O(1) 选择排序 思想 首先在未排序数组中找到最大或者最小元素,然后将其放在起始位置,同理,在未排序数组中继续寻找最大或最小数,将其放在已排序(每次找到元素构成数列...⚠注意:这里交换时,保存是下标,不然无法交换 代码实现 void SelectSort(int* a, int n) { //每轮选出区间内最大元素和最小元素下标 //然后将这两个元素分别和区间最右边和最左边元素交换...&a[end]); begin++; end--; } } 算法分析 时间复杂度:总是O(N^2) 空间复杂度:O(1)

13310

排序算法(二):选择排序

选择排序算法维护一个待排序集合和一个已排序集合,每轮迭代,从待排序集合中选择一个最小(最大)元素,添加到已排序集合中,通过多次迭代,最终完成排序。...] 已排序集合:[] 初始状态为: 根据算法过程: 步骤一, 初始值设为 0,指向元素 6,从下标为 1 元素开始,比较 指向值 和 3,比较大小后,选择下一个元素,比较 指向值...index = j if not index == j: arr[index],arr[j] = arr[j],arr[index] 代码分析 : 以上代码中,第一层循环为需要进行迭代次数...算法分析 在每一轮排序过程中,选择出极值后,是通过直接交换元素位置方式生成已排序元素,所以选择排序是一种非稳定排序。...算法执行过程中,不需要申请额外序列空间来保存临时元素,属于原地排序方式,所以算法空间复杂度为 。

86210

浅析选择排序算法

选择排序(Selection Sort) 一、算法描述 在一个长度为 N 无序数组中,第一次遍历 n 个数找到最大和最后一个数交换。...[1 2 3 4 7 9] 第六趟:最后只剩一位数字我们就不用进行排序了,这样我们就对整个数组按照从小到大顺序进行排序了。...最后排序为 [1 2 3 4 7 9] 二、算法实现 #include int findMaxPos(int arr[], int n){ int max = arr[0];...平均时间复杂度:O(n2) 空间复杂度:O(1) 稳定性:不稳定(例如序列9 8 5 2 5,我们知道第一遍选择第1个元素9会和5交换,那么原序列中2个5相对前后顺序就被破坏了,所以选择排序不是一个稳定排序算法...) 四、适用场景 选择排序适用于数据量很小排序场景,因为选择实现方式较为简单。

76610

直接选择排序算法

直接选择排序算法思想 无序数组a[0…n-1],第一次从a[0]~a[n-1]中选取最小值,与a[0]交换,第二次从a[1]~a[n-1]中选取最小值,与a[1]交换,…....,第n-1次从a[n-2]~a[n-1]中选取最小值,与a[n-2]交换,总共通过n-1次,得到一个按关键字从小到大排列有序序列· 直接选择排序算法过程如下: 给定n=7,数组a中7个元素为[8,3,2,1,7,4,6...---- 在直接选择排序中,共需要进行n-1次选择和交换,每次选择需要进行 n-i 次比较 (1<=i<=n-1),而每次交换最多需要3次移动,因此,总比较次数C=(n*n - n)/2,时间复杂度O...直接选择排序为原地排序,空间复杂度O(1)。直接选择排序不是稳定排序算法。...---- 算法实现 直接选择排序算法代码 //直接排序 SELECTION_SORT(A) { for i=1 to n-1 min=i for j=i+1 to n

1K20

Python算法——选择排序

选择排序(Selection Sort)是一种简单排序算法,它基本思想是在未排序部分中选择最小(或最大)元素,然后将其放在已排序部分末尾。...选择排序核心思想是每一轮选择一个最小元素,并将它交换到已排序部分末尾。这一过程持续多轮,每轮选择一个最小元素,直到整个数组有序。 下面是一个示例,演示选择排序过程。...示例代码 下面是一个使用Python进行选择排序示例代码: def selection_sort(arr): n = len(arr) for i in range(n):...与冒泡排序一样,选择排序不是最高效排序算法,但它是一种简单易懂算法,适用于小型数据集。 总之,选择排序是一种简单排序算法,通过选择最小元素并将其放在已排序部分末尾,实现了排序数组目标。...了解选择排序有助于理解排序算法基本原理,并为学习更高效排序算法奠定了基础。

19310

【小算法选择排序

选择排序是一种非常容易理解算法算法思路 假设有下面一组数据,需要从小到大升序排列。 选择排序算法是 1. 创建一个列表或者数组 2. 第一次遍历数组,找出最小一个数存放在新数组中。 3....Python 代码演示: def sort(srcArr): dstArr = [] size = len(srcArr) while len(dstArr) < size:...时间复杂度 用大 O 表示法,选择排序时间复杂性度是 O(n2)O(n^2)O(n2). 一个列表有 n 个元素,遍历一次需要 n 次操作,所以一次遍历是 O(n)O(n)O(n)....选择排序要进行 n 次遍历,所以时间复杂性度就是 O(n∗n)O(n*n)O(n∗n)。....+2+1)=O((n+1)∗n/2) 但是,在大O 表示法中,常数项可以被省略,所以最终还是要用O(n2)O(n^2)O(n2)表示,这一结果表示选择排序并不快。

89320
领券