冒泡排序算法是我们经常见到的尤其是子一些笔试题中.

下面和大家讨论c#中的冒泡排序,笔者提供了三种解决方案,并且会分析各自的性能优劣.

第一种估计大家都掌握的,使用数据交换来实现,这种就不多说了,园子里的各位前辈分析的都很好,搜一下就有很多.

简单贴一下代码:

  //定义数组
static int[] nums = new int[] { , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , };
static void Main(string[] args)
{
Console.WriteLine("冒泡排序之传统方法");
BubblingOne();
Console.ReadKey();
}
/// <summary>
/// 冒泡排序,传统数据交换实现
/// </summary>
static void BubblingOne()
{
//定义一个需要排序的数组 //定义一个临时变量用于数据交换
int temp; //临时变量,保存最大值
int i, j; //循环变量
for (i = ; i < nums.Length - ; i++)
{
for (j = ; j < nums.Length - - i; j++)
{
if (nums[j] < nums[j + ])
{
temp = nums[j];
nums[j] = nums[j + ];
nums[j + ] = temp;
}
}
}
foreach (int c in nums) //用foreach输出排序后的数组元素
{
Console.Write(c + "\t");
}
}

运行结果如下:

接下来我们介绍第二种实现方法:Linq的查询表达式语法的实现.

关于Linq的介绍请参见:

   /// <summary>
/// linq 冒泡排序算法
/// </summary>
static void BubblingTwo()
{
IEnumerable<int> num = from a in nums orderby a descending select a;
foreach (int item in num)
{
Console.Write(item + "\t");
}
}

请注意我们实现了泛型接口IEnumerable<T>

IEnumerable<T> 是一个接口,通过该接口,可以使用 foreach 语句来枚举泛型集合类。 泛型集合类支持 IEnumerable<T>,就像非泛型集合类(如ArrayList)支持 IEnumerable

运行结果和第一种方法一致.

你可能已经发现了,代码简洁了许多,有原来的8行缩短为一行,这不正是我们的追求吗?尤其是在面试的时候是否为你节约了大量的时间?

那是否还有其他的方式继续实现冒泡排序呢?答案是肯定的,记住我们是对数组中的数据进行操作,Linq有两个扩展方法OrderByDescending和OrderBy用于对数据排序,请参见:对数据进行排序

第三种实现:使用Linq 的扩展方法OrderByDescending(倒序排列)和OrderBy(正序排列)

  /// <summary>
/// 使用Linq的扩展方法OrderByDescending
/// </summary>
static void BubblingThree()
{
IEnumerable<int> num = nums.OrderByDescending(a => a);
foreach (int item in num)
{
Console.Write(item + "\t");
}
}

代码一如既往的简洁.请注意该方式实现了IEnumerable<T>接口.

也许还有更多的实现方式,但本文只介绍这三种方法.

既然有这么多实现方法,我们应该怎么选择用哪种呢,笔者在这里做了一个简单的性能对比(比较各自的执行时间).

首先我们更新以上代码,加入时间的计算:

在为三种方法加入了上图红色区域代码后,我们比较一下不同数据量三种方法各自的表现

插入5条数据

       //5条数据
static int[] nums = new int[] { , , , , };

结果如下:

从上图我们可以简单得出结论,在小数据量是Linq的查询表达式语法表现最差,使用OrderByDescending方法最佳.

下面我们多加几条数据.

  //15条数据
static int[] nums = new int[] { , , , , , , , , , , , , , , };

结果如下:

结果还是OrderByDescending方法领先

我们继续加入数据:

   //50条数据
static int[] nums = new int[] { , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , };

结果如下:

从上图中我们可以看到情况发生了变化,第一种方法领先,然而在我们的测试中丝毫没有看到Linq查询表达式语法(感谢@WAKU的批评)的优势,但对于Linq中的扩展方法OrderByDescing()却有不俗的表现;

以上介绍了在C#下的三种冒泡排序方法以及性能分析.由于数据量较小得出结论难免没有说服力,有兴趣的朋友可已多加数据至数万条。

如果对你有帮助,请帮忙推荐一下.

c#之冒泡排序的三种实现和性能分析的更多相关文章

  1. 三种工厂模式的分析以及C++实现

    三种工厂模式的分析以及C++实现 以下是我自己学习设计模式的思考总结. 简单工厂模式 简单工厂模式是工厂模式中最简单的一种,他可以用比较简单的方式隐藏创建对象的细节,一般只需要告诉工厂类所需要的类型, ...

  2. Mysql Binlog三种格式介绍及分析【转】

    一.Mysql Binlog格式介绍       Mysql binlog日志有三种格式,分别为Statement,MiXED,以及ROW! 1.Statement:每一条会修改数据的sql都会记录在 ...

  3. C2B电商三种主要模式的分析_数据分析师

    C2B电商三种主要模式的分析_数据分析师 在过去的一年中电商领域血雨腥风,尤其是天猫.京东.苏宁.当当.易讯等B2C电商打得不亦乐乎.而随着B2C领域竞争进入白热化阶段,C2B模式也在天猫" ...

  4. C#实例化对象的三种方式及性能对比

    前言 做项目过程中有个需求要实例化两万个对象并添加到List中,这个过程大概需要1min才能加载完(传参较多),于是开启了代码优化之旅,再此记录. 首先想到的是可能实例化比较耗时,于是开始对每种实例化 ...

  5. Day008 三种初始化及内存分析

    三种初始化和内存分析 Java内存分析: 堆: 存放new的对象和数组. 可以被所有的线程共享,不会存放别的对象引用. 栈: 存放基本变量类型(会包含这个基本类型的具体数值). 引用对象的变量(会存放 ...

  6. Windows五种IO模型性能分析和Linux五种IO模型性能分析

    Windows五种IO模型性能分析和Linux五种IO模型性能分析 http://blog.csdn.net/jay900323/article/details/18141217 http://blo ...

  7. 冒泡排序的三种实现(Java)

    冒泡排序是非常好理解的,以从小到大排序为例,每一轮排序就找出未排序序列中最大值放在最后. 设数组的长度为N: (1)比较前后相邻的二个数据,如果前面数据大于后面的数据,就将这二个数据交换. (2)这样 ...

  8. Mysql Binlog 三种格式介绍及分析

    一.Mysql Binlog格式介绍       Mysql binlog日志有三种格式,分别为Statement,MiXED,以及ROW! 1.Statement:每一条会修改数据的sql都会记录在 ...

  9. java list三种遍历方法性能比较

    从c/c++语言转向java开发,学习java语言list遍历的三种方法,顺便测试各种遍历方法的性能,测试方法为在ArrayList中插入1千万条记录,然后遍历ArrayList,发现了一个奇怪的现象 ...

随机推荐

  1. [Django1.6]The MEDIA_ROOT and STATIC_ROOT settings must different 解决

    该项目有一个图片上传功能,为了把上传路径很简单,写在同一个静态文件路径,于wi7执行机器上没问题,今centos我们报道了机上,如下面的错误: django.core.exceptions.Impro ...

  2. 设计模式--模板方法 And State模式

    1.模板方法   钩子: 在抽象基类已经有默认的定义,子类选择是否覆盖它 在模板方法模式中,  抽象基类中使用 钩子函数(子类视情况是否覆盖)  来达到控制模板方法中  流程控制的 目的 设计原则: ...

  3. SQL_sql的简单查询

    ***********************************************声明*************************************************** ...

  4. ubuntu 14.04 安装搜狗拼音输入法

    原文:ubuntu 14.04 安装搜狗拼音输入法 ubuntu桌面系统下终于有了好用的拼音法-搜狗拼音输入法,欲在ubuntu 14.04下安装搜狗拼音输入法相当的简单. 先到搜狗拼音官网下载对应的 ...

  5. 2014ACM/ICPC亚洲区域赛牡丹江站汇总

    球队内线我也总水平,这所学校得到了前所未有的8地方,因为只有两个少年队.因此,我们13并且可以被分配到的地方,因为13和非常大的数目.据领队谁oj在之上a谁去让更多的冠军.我和tyh,sxk,doub ...

  6. hdu2369 Broken Keyboard(类似dfs)

    转载请注明出处:http://blog.csdn.net/u012860063 题目链接:pid=2369">http://acm.hdu.edu.cn/showproblem.php ...

  7. 霍夫曼(最优二叉树)和Java达到

    一.定义 一些定义: 节点之间的路径长度:在从节点树中的一个节点也经历分公司,这构成的两个节点之间的路径分支的数目后这就是所谓的路径长度 的路径长度:从树的根节点到树中每一结点的路径长度之和. 在结点 ...

  8. Python判断内网IP

    def ip_into_int(ip): # 先把 192.168.1.13 变成16进制的 c0.a8.01.0d ,再去了"."后转成10进制的 3232235789 即可. ...

  9. poj 3254 Corn Fields 国家压缩dp

    意甲冠军: 要在m行n陆行,有一些格您可以种树,别人做不到的.不相邻的树,我问了一些不同的共同拥有的法律. 分析: 从后往前种,子问题向父问题扩展,当种到某一格时仅仅有他和他后面的n-1个格子的情况对 ...

  10. P31RestKit.dll 2.0 Unity3d json

    using System.Collections.Generic; using UnityEngine; using System.Collections; using Prime31; public ...