当前位置: 首页 > news >正文

C#系列-数据结构+递归算法+排序算法(3)

  1. C#数据结构

C#中,数据结构是用于组织和管理数据的方式,以便更有效地进行数据的存储、访问和操作。数据结构对于算法的性能和设计至关重要,因为它们决定了数据如何在内存中布局以及如何与算法进行交互。C#提供了许多内置的数据结构,如数组、列表、队列、栈、字典、集合等,这些数据结构都定义在System.CollectionsSystem.Collections.Generic命名空间中。

以下是一些在C#中常用的数据结构:

  1. 数组(Array:数组是一种线性数据结构,用于存储相同类型的元素集合。数组中的每个元素都可以通过索引访问。
  2. 列表(List:List<T>是一个泛型集合,提供了比数组更多的灵活性。它支持动态增长和缩减,允许在列表中进行元素的插入和删除操作。
  3. 队列(Queue:队列是一种先进先出(FIFO)的数据结构,用于存储待处理的项目。Queue<T>类实现了队列数据结构。
  4. 栈(Stack:栈是一种后进先出(LIFO)的数据结构,用于存储数据项,并允许添加和移除元素。Stack<T>类实现了栈数据结构。
  5. 字典(Dictionary:字典是一种键值对集合,允许通过键快速查找对应的值。Dictionary<TKey, TValue>类实现了字典数据结构。
  6. 集合(Set:集合是一种不包含重复元素的数据结构。HashSet<T>类提供了集合的实现,它基于哈希表来存储元素。
  7. 链表(LinkedList:链表是一种元素间通过链接关系连接在一起的数据结构。LinkedList<T>类实现了双向链表。
  8. 树(Tree:树是一种非线性的数据结构,具有层次结构。C#中没有内置的树结构,但可以通过类来实现,如二叉树、AVL树、红黑树等。
  9. 图(Graph:图是由节点(顶点)和边组成的数据结构。C#同样没有内置的图形数据结构,但可以通过自定义类来实现。

每种数据结构都有其特定的用途和性能特点。例如,数组在访问元素时非常高效,但在插入和删除元素时可能效率较低。列表、队列、栈和字典等数据结构提供了更多的灵活性和操作选项。

在选择数据结构时,应该考虑数据的性质(如大小、是否可变、是否允许重复等)以及需要执行的操作(如查找、插入、删除等),以便选择最适合的数据结构来优化算法的性能。

2.C#递归算法

 递归算法是一种解决问题的方法,其中函数或算法直接或间接地调用自身来解决问题。递归在C#编程中是一种常见的算法设计模式,特别是在处理一些具有嵌套结构或分而治之策略的问题时。递归算法通常用于处理列表、树、图等数据结构。

以下是一个C#中递归算法的例子,它演示了如何使用递归计算阶乘:

csharp代码

using System;

class Program

{

static void Main()

{

int number = 5;

int result = Factorial(number);

Console.WriteLine($"The factorial of {number} is {result}");

}

static int Factorial(int n)

{

if (n == 0)

{

return 1;

}

else

{

return n * Factorial(n - 1);

}

}

}

在这个例子中,Factorial 方法是一个递归方法,它接受一个整数 n 作为参数。如果 n 0,方法返回1(因为0的阶乘定义为1)。否则,它返回 n 乘以 n-1 的阶乘。递归调用 Factorial(n - 1) 会继续执行,直到 n 变为0,此时递归停止并返回计算结果。

递归算法需要小心处理,因为不正确的递归实现可能会导致无限递归(栈溢出),特别是当递归条件没有正确设置或递归调用没有正确终止时。

另一个递归算法的例子是斐波那契数列的生成:

csharp代码

using System;

class Program

{

static void Main()

{

int n = 10;

int fibonacciNumber = Fibonacci(n);

Console.WriteLine($"The {n}th Fibonacci number is {fibonacciNumber}");

}

static int Fibonacci(int n)

{

if (n <= 1)

{

return n;

}

else

{

return Fibonacci(n - 1) + Fibonacci(n - 2);

}

}

}

在这个例子中,Fibonacci 方法递归地计算第 n 个斐波那契数。如果 n 小于或等于1,它直接返回 n。否则,它递归地调用自身来计算前两个斐波那契数的和。这种实现虽然直观,但是效率非常低,因为它进行了大量的重复计算。在实践中,通常会使用其他方法(如动态规划)来优化斐波那契数列的计算。

递归算法需要仔细考虑其递归条件和递归终止条件,以确保算法的正确性和效率。此外,对于大型问题,递归可能会导致大量的函数调用和内存使用,因此应该谨慎使用,并在必要时考虑使用迭代方法或其他优化技术。

3.C#排序算法

 C#中,排序算法用于将一系列数据元素按照某种顺序(如升序或降序)进行排列。C# 语言本身提供了几种内置的排序方法,例如 Array.Sort()List<T>.Sort(),以及LINQ扩展方法 OrderBy()  OrderByDescending()。这些内置方法通常基于高效的排序算法实现,如快速排序、堆排序或归并排序。

此外,你还可以实现自己的排序算法,以了解排序过程的基本原理或为了满足特定的需求。以下是一些常见的排序算法及其在C#中的简单实现:

  1. 冒泡排序(Bubble Sort

csharp代码

public static void BubbleSort(int[] array)

{

int n = array.Length;

for (int i = 0; i < n - 1; i++)

{

for (int j = 0; j < n - i - 1; j++)

{

if (array[j] > array[j + 1])

{

// 交换元素

int temp = array[j];

array[j] = array[j + 1];

array[j + 1] = temp;

}

}

}

}

  1. 选择排序(Selection Sort

csharp代码

public static void SelectionSort(int[] array)

{

int n = array.Length;

for (int i = 0; i < n - 1; i++)

{

int minIndex = i;

for (int j = i + 1; j < n; j++)

{

if (array[j] < array[minIndex])

{

minIndex = j;

}

}

// 交换找到的最小元素与第一个未排序位置的元素

int temp = array[minIndex];

array[minIndex] = array[i];

array[i] = temp;

}

}

  1. 插入排序(Insertion Sort

csharp代码

public static void InsertionSort(int[] array)

{

int n = array.Length;

for (int i = 1; i < n; i++)

{

int key = array[i];

int j = i - 1;

// 将大于key的元素向右移动

while (j >= 0 && array[j] > key)

{

array[j + 1] = array[j];

j--;

}

array[j + 1] = key;

}

}

  1. 快速排序(Quick Sort

csharp代码

public static void QuickSort(int[] array, int low, int high)

{

if (low < high)

{

int pi = Partition(array, low, high);

QuickSort(array, low, pi - 1);

QuickSort(array, pi + 1, high);

}

}

private static int Partition(int[] array, int low, int high)

{

int pivot = array[high];

int i = (low - 1);

for (int j = low; j <= high - 1; j++)

{

if (array[j] < pivot)

{

i++;

int temp = array[i];

array[i] = array[j];

array[j] = temp;

}

}

int temp = array[i + 1];

array[i + 1] = array[high];

array[high] = temp;

return i + 1;

}

在使用这些排序算法时,需要注意它们的性能特点。例如,冒泡排序和选择排序的时间复杂度为O(n^2),在处理大数据集时可能效率较低。而快速排序和归并排序等更高效的算法在平均和最坏情况下的性能会有所不同。

对于大多数日常应用,推荐使用C#内置的排序方法,因为它们已经过优化,并且通常比手动实现的算法更加高效和稳定。然而,理解这些排序算法的原理和实现对于学习计算机科学和算法设计仍然非常重要。

相关文章:

C#系列-数据结构+递归算法+排序算法(3)

C#数据结构 在C#中&#xff0c;数据结构是用于组织和管理数据的方式&#xff0c;以便更有效地进行数据的存储、访问和操作。数据结构对于算法的性能和设计至关重要&#xff0c;因为它们决定了数据如何在内存中布局以及如何与算法进行交互。C#提供了许多内置的数据结构&#xf…...

Redis实现秒杀

前期准备 缓存选择考虑 Redis和Redis Cluster&#xff08;分布式版本&#xff09;&#xff0c;是一个分布式缓存系统。其支持多种数据结构&#xff0c;也支持MQ。Redis在性能上做了大量优化。因此使用Redis或者Redis Cluster就可以轻松实现一个强大的秒杀系统。 用Redis的这…...

4 scala集合-Map

和 Java 一样&#xff0c;Scala 也有表示键值对&#xff08;Key-Value&#xff09;集合的 Map 数据结构。同样&#xff0c;Map 也分不可变和可变&#xff0c;不可变需要使用类 scala.collection.mutable.Map。 1 不可变 Map 可以使用以下语法定义不可变 Map 对象 val/var ma…...

QT 对象树模型

QObject是Qt里边绝大部分类的根类 QObject对象之间是以对象树的形式组织起来的。 当两个QObject&#xff08;或子类&#xff09;的对象建立了父子关系的时候。子对象就会加入到父对象的一个成员变量叫children&#xff08;孩子&#xff09;的list&#xff08;列表&#xff09;…...

ubuntu快速安装miniconda

ubuntu快速安装miniconda 环境 ubuntu.22.04 显卡 RTX 3050 关于选择Miniconda还是Anaconda的问题&#xff0c;Anaconda安装包比较大&#xff0c;耗时比较长&#xff0c;如果你是绝对的初学者&#xff0c;选择Anaconda会比较稳妥一些&#xff1b;否则建议你还是选择Miniconda安…...

阿里云游戏服务器多少钱一年?

阿里云游戏服务器租用价格表&#xff1a;4核16G服务器26元1个月、146元半年&#xff0c;游戏专业服务器8核32G配置90元一个月、271元3个月&#xff0c;阿里云服务器网aliyunfuwuqi.com分享阿里云游戏专用服务器详细配置和精准报价&#xff1a; 阿里云游戏服务器租用价格表 阿…...

小游戏和GUI编程(7) | SimpleNN 界面源码解析

小游戏和GUI编程(7) | SimpleNN 界面源码解析 0. 简介 SimpleNN 是 AdamYuan 在高中一年级时用 1 天时间写出来的简易 CNN, 使用 SFML 做 UI, 用于交互式输入手写数字&#xff0c;这个数字被训练好的 CNN 网络执行推理得到识别结果, 它的运行效果如下&#xff1a; 这一篇我们…...

c++设计模式之代理模式

作用 代理模式主要用于&#xff0c;通过代理类&#xff0c;来控制实际对象的访问权限 案例 class VideoSite { public:virtual void freeVideo()0;virtual void vipVideo()0;virtual void trickVideo()0; };class FixBugVideoSite:public VideoSite { public:void freeVideo()…...

第5个-模糊加载

Day 5 - Blurry Loading 1. 项目展示 2. 分析思路 变化过程 数字从 0 不断增长到 100&#xff1b;中间的百分比数字逐渐消失&#xff0c;即透明度 opacity 从 1 到 0&#xff1b;背景图片从模糊变为清晰&#xff0c;滤镜 filter.blur()的参数设置为从 30px 到 0px。 小 tips…...

rtt设备io框架面向对象学习-adc设备

目录 1.adc设备基类2.adc设备基类的子类3.初始化/构造流程3.1设备驱动层3.2 设备驱动框架层3.3 设备io管理层 4.总结5.使用 1.adc设备基类 此层处于设备驱动框架层。也是抽象类。 在/ components / drivers / include / drivers 下的adc.h定义了如下adc设备基类 struct rt_ad…...

面试官:介绍一下Exception和Error之间的区别

前言 大家好&#xff0c;我是chowley&#xff0c;在我之前的面试中&#xff0c;遇到过这样一个问题&#xff1a;Exception和Error之间有什么区别&#xff1f;今天我就来好好地总结一下&#xff01; 主体 在Java编程中&#xff0c;Exception和Error都是Java中的可抛出对象&am…...

【RabbitMQ(一)】:基本介绍 | 配置安装与快速入门

应该是新年前最后一篇博客了&#xff0c;明天浅浅休息一下&#xff0c;提前祝大家新年快乐捏&#xff01;&#x1f60a;&#x1f60a;&#x1f60a; 01. 基础理解 1.1 同步调用和异步调用 &#x1f449; 同步调用 的时候调用者会 阻塞 等待被调用函数或方法执行完成&#xff…...

ElasticSearch之search API

写在前面 本文看下查询相关内容&#xff0c;这也是我们在实际工作中接触的最多的&#xff0c;所以有必要好好学习下&#xff01; 1&#xff1a;查询的分类 主要分为如下2类&#xff1a; 1:基于get查询参数的URI search 2&#xff1a;基于post body的request body search&am…...

07-Java桥接模式 ( Bridge Pattern )

Java桥接模式 摘要实现范例 桥接模式&#xff08;Bridge Pattern&#xff09;是用于把抽象化与实现化解耦&#xff0c;使得二者可以独立变化 桥接模式涉及到一个作为桥接的接口&#xff0c;使得实体类的功能独立于接口实现类&#xff0c;这两种类型的类可被结构化改变而互不影…...

golang集成sentry: go-redis

网上没有找到go-redis集成sentry的库&#xff0c; 所以我简单实现了一个 代码&#xff1a; https://github.com/Shujie-Tan/go-redis-sentry 使用方法&#xff1a; import (redis_sentry "github.com/Shujie-Tan/go-redis-sentry" ) rdb : redis.NewClient(&re…...

用EXCEL从地址(上海)中提取各区(浦东新区等区)信息

背景&#xff1a; 朋友工作需要经常用EXCEL把各上海用户收货地址中的区提取出来&#xff0c;之前一直手动处理&#xff0c;希望我帮忙用EXCEL公式直接提取处理。 数据样式&#xff1a; 中国上海市浦东新区A小区 上海徐汇区B小区 中国&#xff0c;上海&#xff0c;浦东新区&a…...

关于在分布式环境中RVN和使用场景的介绍3

简介 在《关于在分布式环境中RVN和使用场景的介绍2》和《关于在分布式环境中RVN和使用场景的介绍1》中我们介绍了RVN的概念和在一些具体用例中的使用。在本文中我们讨论一下在分布式环境中使用RVN需要注意的问题。 问题 我们在收到一条待处理的事件时&#xff0c;需要检查该…...

计算最小公倍数math.lcm()

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 计算最小公倍数 math.lcm() 请问以下代码输出的结果是&#xff1f; import math print("【执行】math.lcm(2, 4)") print(math.lcm(2, 4)) print("【执行】math.lcm(1, 2, 3…...

VUE SEO 几种方案经典面试题

1、SSR服务器渲染 Vue.js 是构建客户端应用程序的框架。默认情况下&#xff0c;可以再浏览器中输出Vue组件&#xff0c;进行生成DOM和操作DOM。然而&#xff0c;也可以将同一个组件渲染未服务器端的HTML字符串&#xff0c;将它们直接发送到浏览器&#xff0c;最后将这些静态标…...

Python和VBA批量提取Word中的表格

表格在word文档中常见的文档元素之一。操作word文件时有时需要提取文件中多个表格的内容到一个新的文件&#xff0c;甚至有时还会要提取题注信息。 今天&#xff0c;给大家分享两种批量提取文档中表格的两种方法&#xff0c;分别是VBA法和Python法两种。 一、VBA法提取word中…...

java 实现excel文件转pdf | 无水印 | 无限制

文章目录 目录 文章目录 前言 1.项目远程仓库配置 2.pom文件引入相关依赖 3.代码破解 二、Excel转PDF 1.代码实现 2.Aspose.License.xml 授权文件 总结 前言 java处理excel转pdf一直没找到什么好用的免费jar包工具,自己手写的难度,恐怕高级程序员花费一年的事件,也…...

STM32F4基本定时器使用和原理详解

STM32F4基本定时器使用和原理详解 前言如何确定定时器挂载在哪条时钟线上配置及使用方法参数配置PrescalerCounter ModeCounter Periodauto-reload preloadTrigger Event Selection 中断配置生成的代码及使用方法初始化代码基本定时器触发DCA或者ADC的代码讲解中断代码定时启动…...

ElasticSearch搜索引擎之倒排索引及其底层算法

文章目录 一、搜索引擎1、什么是搜索引擎?2、搜索引擎的分类3、常用的搜索引擎4、搜索引擎的特点二、倒排索引1、简介2、为什么倒排索引不用B+树1.创建时间长,文件大。2.其次,树深,IO次数可怕。3.索引可能会失效。4.精准度差。三. 倒排索引四、算法1、Term Index的算法2、 …...

【Oracle】分区表

个人主页&#xff1a;Guiat 归属专栏&#xff1a;Oracle 文章目录 1. 分区表基础概述1.1 分区表的概念与优势1.2 分区类型概览1.3 分区表的工作原理 2. 范围分区 (RANGE Partitioning)2.1 基础范围分区2.1.1 按日期范围分区2.1.2 按数值范围分区 2.2 间隔分区 (INTERVAL Partit…...

数学建模-滑翔伞伞翼面积的设计,运动状态计算和优化 !

我们考虑滑翔伞的伞翼面积设计问题以及运动状态描述。滑翔伞的性能主要取决于伞翼面积、气动特性以及飞行员的重量。我们的目标是建立数学模型来描述滑翔伞的运动状态,并优化伞翼面积的设计。 一、问题分析 滑翔伞在飞行过程中受到重力、升力和阻力的作用。升力和阻力与伞翼面…...

规则与人性的天平——由高考迟到事件引发的思考

当那位身着校服的考生在考场关闭1分钟后狂奔而至&#xff0c;他涨红的脸上写满绝望。铁门内秒针划过的弧度&#xff0c;成为改变人生的残酷抛物线。家长声嘶力竭的哀求与考务人员机械的"这是规定"&#xff0c;构成当代中国教育最尖锐的隐喻。 一、刚性规则的必要性 …...

用鸿蒙HarmonyOS5实现国际象棋小游戏的过程

下面是一个基于鸿蒙OS (HarmonyOS) 的国际象棋小游戏的完整实现代码&#xff0c;使用Java语言和鸿蒙的Ability框架。 1. 项目结构 /src/main/java/com/example/chess/├── MainAbilitySlice.java // 主界面逻辑├── ChessView.java // 游戏视图和逻辑├── …...

Element-Plus:popconfirm与tooltip一起使用不生效?

你们好&#xff0c;我是金金金。 场景 我正在使用Element-plus组件库当中的el-popconfirm和el-tooltip&#xff0c;产品要求是两个需要结合一起使用&#xff0c;也就是鼠标悬浮上去有提示文字&#xff0c;并且点击之后需要出现气泡确认框 代码 <el-popconfirm title"是…...

基于小程序老人监护管理系统源码数据库文档

摘 要 近年来&#xff0c;随着我国人口老龄化问题日益严重&#xff0c;独居和居住养老机构的的老年人数量越来越多。而随着老年人数量的逐步增长&#xff0c;随之而来的是日益突出的老年人问题&#xff0c;尤其是老年人的健康问题&#xff0c;尤其是老年人产生健康问题后&…...

HTML版英语学习系统

HTML版英语学习系统 这是一个完全免费、无需安装、功能完整的英语学习工具&#xff0c;使用HTML CSS JavaScript实现。 功能 文本朗读练习 - 输入英文文章&#xff0c;系统朗读帮助练习听力和发音&#xff0c;适合跟读练习&#xff0c;模仿学习&#xff1b;实时词典查询 - 双…...