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日

相关文章

  • sqlserver利用存储过程去除重复行的sql语句

    sqlserver利用存储过程去除重复行的SQL语句攻略: 创建存储过程 首先需要在SQL Server中创建存储过程,以下是示例代码: CREATE PROCEDURE RemoveDuplicateRows AS BEGIN SET NOCOUNT ON; SELECT DISTINCT * INTO #TempTable FROM YourTableN…

    C# 2023年6月2日
    00
  • C# Mysql 查询 Rownum的解决方法

    下面就给你详细讲解C#和Mysql查询Rownum的解决方法。 什么是Rownum Rownum是Oracle数据库中的一个概念,用于获取指定条件下的前N条记录,但是在Mysql中并没有Rownum,可以通过一些技巧模拟出来。 解决方法 方法一:使用变量模拟Rownum 通过定义一个变量,然后根据变量的值来返回前N条结果。 SET @num := 0, @r…

    C# 2023年5月15日
    00
  • Asp.NET 多层登陆实现代码

    本文将详细讲解如何利用 Asp.NET 实现多层登陆,以下是完整的实现攻略: 第一步:创建用户数据库 在创建用户数据库之前,必须先安装 Microsoft SQL Server 数据库并创建一个新的数据库。可以按照以下步骤创建一个新的用户数据库: 打开 Microsoft SQL Server 的管理工具(如SqlServer Management Stud…

    C# 2023年5月31日
    00
  • 5分钟用C#实现串口助手

    让我们来详细讲解一下“5分钟用C#实现串口助手”的完整攻略。 准备工作 在开始编写代码之前,我们需要准备一些工作: 安装 Visual Studio IDE 或者其他 C# 编辑器 打开 Visual Studio,并新建一个控制台应用程序项目 在项目中添加 System.IO.Ports 命名空间 实现串口初始化 首先,我们需要初始化串口,让它与我们的计算…

    C# 2023年5月15日
    00
  • Win11 KB5012643造成 .Net 应用程序崩溃怎么办

    最近有用户反映,在安装了Windows 11 KB5012643更新后,运行.NET应用程序时会出现崩溃的情况。本文将提供解决方案,帮助用户解决这个问题。 问题描述 在安装了Windows 11 KB5012643更新后,运行.NET应用程序时会出现崩溃的情况。具体表现为,应用程序会在启动时崩溃,或者在使用某些功能时崩溃。 解决方案 方法一:卸载KB5012…

    C# 2023年5月15日
    00
  • 输出的文本实现对齐的方法(超简单)

    概述: 实现文本输出对齐的方法有很多,其中最简单的方法就是使用Markdown语法中的制表符\t。制表符\t可以在文本中插入一个制表符,从而实现对齐。 步骤: 1、在需要对齐的文本中,使用制表符\t进行对齐。制表符\t的作用就是让文本输出一个制表符的位置,从而实现对齐。 2、在Markdown语法中,需要使用代码块(反引号)将代码块包含起来。代码块中的内容会…

    C# 2023年6月7日
    00
  • C#实现带消息数的App图标

    下面就为大家介绍一下如何用C#实现带消息数的App图标的步骤。 1. 准备工作 首先,你需要创建一个Windows Forms应用程序。然后,从CustomControls目录(你需要从NuGet中安装此组件)中添加一个NotifyIcon控件并将其拖放到你的主窗体中。 2. 实现带消息数的App图标 要实现带消息数的App图标,我们需要设置NotifyIc…

    C# 2023年6月1日
    00
  • 详解 iOS 系统中的视图动画

    详解 iOS 系统中的视图动画 介绍 视图动画是 iOS 开发中常用的一种动画效果,它可以让应用的用户界面更加生动有趣,提高用户的交互体验。iOS 系统提供了许多动画特效供开发者使用,本文将介绍如何在 iOS 应用中实现常用的视图动画效果。 动画基础 要实现视图动画效果,首先需要了解 iOS 中动画的基础知识。在 iOS 中,我们通常使用 Core Anim…

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