C#算法之冒泡排序、插入排序、选择排序

C#算法之冒泡排序、插入排序、选择排序

在学习C#算法的过程中,冒泡排序、插入排序、选择排序是最基础且常用的排序算法之一。这些排序算法可以对数组进行排序,使其按照升序或降序排列。

本文将详细讲解这三种排序算法的原理和实现步骤,并提供两个示例说明。

冒泡排序

冒泡排序是一种比较简单的排序算法,其基本思想是:将相邻的两个元素进行比较,如果前一个元素比后一个元素大,就交换它们的位置。

具体实现步骤如下:

  1. 从数组的第一个元素开始,依次将相邻的两个元素进行比较,如果顺序不对,则交换它们的位置。

  2. 把数组中的元素全部比较一遍后,确定最后一个元素是最大或最小的,然后再重复以上步骤,但是不再比较最后一个元素。

  3. 重复以上步骤,直到所有元素都排序完成。

冒泡排序的时间复杂度为O(n^2),未排序的数组越大,所需的时间就越长。代码示例如下:

public static void BubbleSort(int[] arr)
{
    int temp;

    for (int i = 0; i < arr.Length - 1; i++)
    {
        for (int j = 0; j < arr.Length - i - 1; j++)
        {
            if (arr[j] > arr[j + 1])
            {
                temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}

示例1:对数组{5, 3, 8, 6, 4}进行冒泡排序,结果应该为{3, 4, 5, 6, 8}。

int[] arr = {5, 3, 8, 6, 4};
BubbleSort(arr);
foreach (int i in arr)
{
    Console.Write(i + " ");
}

输出结果为:3 4 5 6 8

插入排序

插入排序是通过构建有序序列,对于未排序的数据,在已排序序列中从后向前扫描,找到相应位置并插入。具体实现步骤如下:

  1. 从第一个元素开始,该元素可以认为已经被排序。

  2. 取出下一个元素,在已经排序的元素序列中从后向前扫描。

  3. 如果已排序的元素大于新元素,将该元素移到下一个位置。

  4. 重复步骤3,直到已排序的元素小于或等于新元素。

  5. 将新元素插入到该位置后。

  6. 重复步骤2~5,直到所有元素都排序完成。

插入排序的时间复杂度为O(n^2)。代码示例如下:

public static void InsertionSort(int[] arr)
{
    for (int i = 1; i < arr.Length; i++)
    {
        int value = arr[i];
        int j = i - 1;
        while (j >= 0 && arr[j] > value)
        {
            arr[j + 1] = arr[j];
            j--;
        }
        arr[j + 1] = value;
    }
}

示例2:对数组{12, 11, 13, 5, 6}进行插入排序,结果应该为{5, 6, 11, 12, 13}。

int[] arr = { 12, 11, 13, 5, 6 };
InsertionSort(arr);
foreach (int i in arr)
{
    Console.Write(i + " ");
}

输出结果为:5 6 11 12 13

选择排序

选择排序也是一种简单的排序算法,其基本思想是每次找到最小值或最大值,将其放到数组的最前面或最后面,然后对剩余的未排序的元素重复以上步骤。具体实现步骤如下:

  1. 在未排序的元素中找到最小值或最大值,将其放到序列的起始位置。

  2. 从剩余未排序的元素中继续寻找最小值或最大值,放到已排序的序列的末尾。

  3. 重复步骤2,直到所有元素都排序完成。

选择排序的时间复杂度也是O(n^2)。代码示例如下:

public static void SelectionSort(int[] arr)
{
    for (int i = 0; i < arr.Length - 1; i++)
    {
        int minIndex = i;
        for (int j = i + 1; j < arr.Length; j++)
        {
            if (arr[j] < arr[minIndex])
            {
                minIndex = j;
            }
        }
        int temp = arr[i];
        arr[i] = arr[minIndex];
        arr[minIndex] = temp;
    }
}

示例3:对数组{64, 25, 12, 22, 11}进行选择排序,结果应该为{11, 12, 22, 25, 64}。

int[] arr = { 64, 25, 12, 22, 11 };
SelectionSort(arr);
foreach (int i in arr)
{
    Console.Write(i + " ");
}

输出结果为:11 12 22 25 64

以上便是冒泡排序、插入排序、选择排序的详细介绍和代码示例。在实际应用中,可以根据具体场景选择不同的排序算法来提高效率和准确性。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:C#算法之冒泡排序、插入排序、选择排序 - Python技术站

(0)
上一篇 2023年6月8日
下一篇 2023年6月8日

相关文章

  • C# 9 新特性之增强的foreach详解

    C# 9 新特性之增强的 foreach 详解 简介 在 C# 9 中,foreach 循环得到了一些增强,包括更好的性能,支持使用 ref 局部变量以及对 IAsyncEnumerable 类型的异步迭代支持。 更好的性能 在 C# 9 中,foreach 的性能得到了提升。它会通过对枚举器对象的优化,减少一些额外的开销,以获得更好的性能。 ref 局部变…

    C# 2023年6月6日
    00
  • C# 并行和多线程编程——认识和使用Task

    C#并行和多线程编程——认识和使用Task 在C#中,Task类是用来支持并行和多线程编程的。本文将详细介绍如何使用Task类。 Task的定义 Task类是C#中用来提供线程执行的工具类,使用Task,可以异步执行计算任务、并行处理集合等。Task可以并行执行多个任务,加快程序的执行速度,提高程序的响应速度。 Task的创建和使用 通过Task类创建的任务…

    C# 2023年5月15日
    00
  • Vue与.net Core 接收List<T>泛型参数

    Vue与.NET Core接收List泛型参数攻略 在Vue和.NET Core应用程序之间进行数据交互时,有时需要传递List泛型参数。本文将介绍如何在Vue和.NET Core应用程序之间接收List泛型参数,以及如何在Vue中使用axios库发送请求。 步骤 步骤1:在Vue中使用axios库发送请求 首先,我们需要在Vue中使用axios库发送请求。…

    C# 2023年5月17日
    00
  • c# 开发文字识别软件

    C#开发文字识别软件攻略 1. 确定需求和选取OCR引擎 在开始C#开发文字识别软件之前,我们需要明确需求和选择OCR(Optical Character Recognition,光学字符识别)引擎。OCR引擎是用来识别图片中的文字,将其转换为文本形式的工具。OCR引擎有很多种,我们需要根据实际需求选择适合的引擎。 常见的OCR引擎有Tesseract、百度…

    C# 2023年5月15日
    00
  • C# DataGridView绑定数据源的方法

    下面为你提供C# DataGridView绑定数据源的方法的完整攻略。 方法一:通过设置DataGridView的DataSource属性来绑定数据源 准备好需要绑定的数据源,比如DataTable或者List。 //创建一个DataTable作为数据源 DataTable dt = new DataTable(); dt.Columns.Add(&quot…

    C# 2023年6月2日
    00
  • JS+WCF实现进度条实时监测数据加载量的方法详解

    JS+WCF实现进度条实时监测数据加载量的方法详解 在Web应用程序中,数据加载是一个常见的操作。为了提高用户体验,我们通常需要实现一个进度条来显示数据加载的进度。本文将详细讲解如何使用JS和WCF实现进度条实时监测数据加载量的方法,并提供两个示例。 1. 使用JS实现进度条 以下是使用JS实现进度条的基本步骤: 在HTML页面中,添加一个进度条元素。 &l…

    C# 2023年5月15日
    00
  • C#检查键盘大小写锁定状态的方法

    下面是C#检查键盘大小写锁定状态的方法的完整攻略。 问题背景 在开发应用程序的过程中,有时需要检查当时键盘的大小写锁定状态。例如,当你需要获取用户键入的字母时,如果键盘处于大写状态,那么你需要将其转换为小写,否则你可能无法正确进行后续的操作。因此,检查键盘大小写锁定状态是应用程序开发过程中的一个非常重要的问题。 检查键盘大小写状态的方法 在 C# 中,我们可…

    C# 2023年6月7日
    00
  • ASP.NET MVC4 HtmlHelper扩展类,实现分页功能

    ASP.NET MVC4是一种Web应用程序框架,它提供了一种模型-视图-控制器(MVC)的架构模式,用于构建可扩展的Web应用程序。在ASP.NET MVC4中,HtmlHelper是一个非常有用的类,它提供了许多有用的方法,例如生成HTML标记、表单、分页等。在本文中,我们将介绍如何使用HtmlHelper扩展类来实现分页功能。 步骤一:创建HtmlHe…

    C# 2023年5月17日
    00
合作推广
合作推广
分享本页
返回顶部