这篇文章介绍了C#实现冒泡排序和插入排序算法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
1.选择排序(冒泡排序)
升序
用第一个元素跟其他元素比较,如果该元素比其他元素,则交换,保证该元素是最小的。然后再用第二个元素跟后面其他的比较,保证第二个元素是除第一个最小的。依次循环,直到整个数组。
/// <summary>
/// 选择排序
/// </summary>
public class Selection:BaseSort
{
public static long usedTimes = 0;
public Selection()
{
}
public static void Sort(IComparable[] a)
{
Stopwatch timer = new Stopwatch();
timer.Start();
for (var i = 0; i < a.Length; i++)
{
int minIndex = i;
for (var j = i + 1; j < a.Length; j++)
{
if (Less(a[j], a[minIndex]))
{
Exch(a, j, minIndex);
//minIndex = j;
}
}
}
//交换次数更少,内循环只交换索引,最后再交换值
//for (var i = 0; i < a.Length; i++)
//{
// int minIndex = i;
// for (var j = i + 1; j < a.Length; j++)
// {
// if (Less(a[j], a[minIndex]))
// minIndex = j;
// }
// Exch(a, minIndex, i);
/
沃梦达教程
本文标题为:C#实现冒泡排序和插入排序算法
基础教程推荐
猜你喜欢
- 浅谈C# 构造方法(函数) 2023-03-03
- C#使用NPOI将excel导入到list的方法 2023-05-22
- C#执行EXE文件与输出消息的提取操作 2023-04-14
- C#使用SQL DataAdapter数据适配代码实例 2023-01-06
- C#实现归并排序 2023-05-31
- 如何用C#创建用户自定义异常浅析 2023-04-21
- C#中参数的传递方式详解 2023-06-27
- C#使用Chart绘制曲线 2023-05-22
- C# TreeView从数据库绑定数据的示例 2023-04-09
- Unity虚拟摇杆的实现方法 2023-02-16
