基础排序算法 c#

算法知识欠缺,学习几种基础排序算法,1. 选择排序  2.冒泡排序 3.插入排序

以升序为例,程序中凡是 两个值的比较前者大于后者,则调换位置

1. 选择排序 最容易想到的排序算法,但却不知道这种叫做选择排序法

 1         /// <summary>
 2         /// 选择排序
 3         /// </summary>
 4         /// <param name="sourceValues"></param>
 5         /// <returns></returns>
 6         public static int[] SelectionSortMin2Max(int[] sourceValues)
 7         {
 8             int[] ret = sourceValues;
 9
10             if (sourceValues == null)
11                 return ret;
12
13             //第1个依次跟第2,3,4...个比较,比较得到的较小值放在第1个 结果第1个是最小值
14             //第2个依次跟第3,4...个比较,比较得到的较小值放在第2个    结果第2个是次小值 ...
15             int temp;
16             for (int i = 0; i < ret.Length - 1; i++)
17             {
18                 for (int j = i + 1; j < ret.Length; j++)
19                 {
20                     if (ret[j] < ret[i])
21                     {
22                         temp = ret[i];
23                         ret[i] = ret[j];
24                         ret[j] = temp;
25                     }
26                 }
27             }
28
29             return ret;
30         }

2. 冒泡排序算法 相邻两个值比较(1和2,2和3...N-1和N)  结果第N是最大值

         相邻两个值比较(1和2,2和3...N-2和N-1)结果第N-1是次大值...

 1 /// <summary>
 2         /// 冒泡排序
 3         /// </summary>
 4         /// <param name="sourceValues"></param>
 5         /// <returns></returns>
 6         public static int[] BubbleSortMin2Max(int[] sourceValues)
 7         {
 8             int[] ret = sourceValues;
 9
10             if (sourceValues == null)
11                 return ret;
12
13             // 相邻比较
14             //内层完整循环第一次(第1与第2比较,第2与第3比较...第N-1和第N个比较),冒泡结果ret[ret.length-1]为最大值
15             //内层完整循环第二次(第1与第2比较,第2与第3比较...第N-2和第N-1个比较),冒泡结果ret[ret.length-2]为次大值
16             // ...
17             int temp;
18             for (int i = 0; i < ret.Length-1; i++)
19             {
20                 for(int j = 0; j < ret.Length - i - 1; j++)
21                 {
22                     if (sourceValues[j] > sourceValues[j + 1])
23                     {
24                         temp = sourceValues[j];
25                         sourceValues[j] = sourceValues[j + 1];
26                         sourceValues[j + 1] = temp;
27                     }
28                 }
29             }
30
31             return ret;
32         }

3. 插入排序

 1         /// <summary>
 2         /// 插入排序法
 3         /// </summary>
 4         /// <param name="sourceValue"></param>
 5         /// <returns></returns>
 6         public static int[] insertionSort(int[] sourceValue)
 7         {
 8             int[] ret = sourceValue;
 9             if (sourceValue == null)
10                 return ret;
11
12             //思路:假设前面N个值的顺序是对的,第N+1个值要加进来,则第N+1个值往前冒泡(对比调换位置)直到找到合适的位置
13             //      第1个值往前冒泡后,则第0,1个值是按顺序的
14             //      第2个值往前冒泡后,则第0,1,2个值是按顺序的
15             // ...  第N个值往前冒泡后,则第0,1...N个值是按顺序的
16             int temp;
17             for (int i = 1; i < ret.Length; i++)
18             {
19                 for (int j = i; j >= 1; j--)
20                 {
21                     if (ret[j] >= ret[j - 1])
22                     {
23                         break;
24                     }
25                     temp = ret[j];
26                     ret[j] = ret[j - 1];
27                     ret[j - 1] = temp;
28                 }
29             }
30             return ret;
31         }
时间: 2024-10-09 21:34:19

基础排序算法 c#的相关文章

基础排序算法

七个基础排序算法(均为内部排序): 直接插入排序 希尔排序 冒泡排序 简单选择排序 快速排序 堆排序 二路归并排序 排序算法稳定性:经过排序后,具有相同关键码的元素之间的相对次序保持不变,则称该排序方法是稳定的;否则不稳定. 直接插入排序: void InsertSort(int a[],int n){ // index start at 1, a[0] is temp one int i,j; for(i=2;i<=n;i++){ if(a[i]<a[i-1]){ a[0]=a[i]; a[

九大基础排序算法总结

九大基础排序算法小结 一直想做份总结,总是抽不出时间,趁着周末闲着直接用了一整天做一份,一些内容参考了网上的一些博主的总结,还有网络上的一些图片. 好了,接下来就看看内容吧! 排序算法: 排序方法 时间复杂度 空间复杂度 稳定性 选用情况 平均情况 最坏情况 最好情况 Insertion Sort O(n^2) O(n^2) O(n) O(1) 稳定 n较小时 Selection Sort O(n^2) O(n^2) O(n^2) O(1) 不稳定 n较小时 Bubble Sort O(n^2)

php四种基础排序算法的运行时间比较!

/** * php四种基础排序算法的运行时间比较 * @authors Jesse (jesse152@163.com) * @date 2016-08-11 07:12:14 */ //冒泡排序法 function bubbleSort($array){ $temp = 0; for($i = 0;$i < count($array) -1;$i++){ for($j = 0;$j < count($array) - 1 -$i;$j++){ if($array[$j] > $arra

php四种基础排序算法的运行时间比较

/** * php四种基础排序算法的运行时间比较 * @authors Jesse (jesse152@163.com) * @date 2016-08-11 07:12:14 */ //冒泡排序法 function bubbleSort($array){ $temp = 0; for($i = 0;$i < count($array) -1;$i++){ for($j = 0;$j < count($array) - 1 -$i;$j++){ if($array[$j] > $arra

基础排序算法详解与优化

常见的基础排序有选择排序.冒泡排序和插入排序.众所周知,他们的时间复杂度是 O(n\*n). 但是,现在要重新认识一下基础排序算法,尤其是“插入排序”:在近乎有序的情况下,插入排序的时间复杂度可以降低到 O(n)的程度. 因此,在处理系 原文地址:https://www.cnblogs.com/wdyff/p/9749837.html

第3章.基础排序算法

3.1.1 数组类测试环境 为了检验这些算法,首先需要构造一个可以实现并测试算法的测试环境.这里将构造一个类来封装数组处理的一些常规操作,即元素插入操作,元素存取访问操作,以及显示数组内容的操作.下面就是程序的代码: namespace 第3章.基础排序算法 { class Program { static void Main(string[] args) { CArry nums = new CArry(50); for (int i = 0; i <= 49; i++) { nums.Ins

程序员,你应该知道的基础排序算法

冒泡排序(Bubble Sort) 原理 冒泡排序只会操作相邻的两个数据.每次冒泡操作都会对相邻的两个元素进行比较,看是否满足大小关系要求.如果不满足就让它俩互换.一次冒泡会让至少一个元素移动到它应该在的位置,重复 n 次,就完成了 n 个数据的排序工作. 图解 图片来源网络,侵权即删 性能 时间复杂度:O(n2) 最好时间复杂度:O(n) 最差时间复杂度:O(n2) 平均时间复杂度:O(n2) 空间复杂度:O(1) 代码 public static void bubbleSort(int[]

基础排序算法—冒泡,插入,选择

前言 冒泡,插入,选择这三种基础的排序算法,比较简单效率不高,工作中一般不会使用,但是当做算法来研究还是能了解一些知识的,本文以<数据结构与算法之美>为基础,详细解析一下. 正文 首先要引入几个概念 稳定性 如果待排序数组中有相同的元素,排序过后它们的相对顺序不发生变化. 比如 2,9,3,4,8,3 排序过后为2, 3 , 3, 4, 8, 9 这两个3的相对顺序不变.这样就是具有稳定性. 稳定性可以保证复杂数据结构排序时的相对有序性. 比如我们要对一笔订单先按金额排列,金额相同的再按时间排

数据结构基础 排序算法(一) 概念篇

本辑将会对笔试面试最常涉及到的12种排序算法(包括插入排序.二分插入排序.希尔排序.选择排序.冒泡排序.鸡尾酒排序.快速排序.堆排序.归并排序.桶排序.计数排序和基数排序)进行详解.每一种算法都有基本介绍.算法原理分析.图解演示.算法代码.笔试面试重点分析.笔试面试题等板块. 一.插入排序 1)算法简介 插入排序(Insertion Sort)的算法描述是一种简单直观的排序算法.它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入.插入排序在实现上,通常