C#系列-数据结构+递归算法+排序算法(3)
- C#数据结构
在C#中,数据结构是用于组织和管理数据的方式,以便更有效地进行数据的存储、访问和操作。数据结构对于算法的性能和设计至关重要,因为它们决定了数据如何在内存中布局以及如何与算法进行交互。C#提供了许多内置的数据结构,如数组、列表、队列、栈、字典、集合等,这些数据结构都定义在System.Collections和System.Collections.Generic命名空间中。
以下是一些在C#中常用的数据结构:
- 数组(Array):数组是一种线性数据结构,用于存储相同类型的元素集合。数组中的每个元素都可以通过索引访问。
- 列表(List):List<T>是一个泛型集合,提供了比数组更多的灵活性。它支持动态增长和缩减,允许在列表中进行元素的插入和删除操作。
- 队列(Queue):队列是一种先进先出(FIFO)的数据结构,用于存储待处理的项目。Queue<T>类实现了队列数据结构。
- 栈(Stack):栈是一种后进先出(LIFO)的数据结构,用于存储数据项,并允许添加和移除元素。Stack<T>类实现了栈数据结构。
- 字典(Dictionary):字典是一种键值对集合,允许通过键快速查找对应的值。Dictionary<TKey, TValue>类实现了字典数据结构。
- 集合(Set):集合是一种不包含重复元素的数据结构。HashSet<T>类提供了集合的实现,它基于哈希表来存储元素。
- 链表(LinkedList):链表是一种元素间通过链接关系连接在一起的数据结构。LinkedList<T>类实现了双向链表。
- 树(Tree):树是一种非线性的数据结构,具有层次结构。C#中没有内置的树结构,但可以通过类来实现,如二叉树、AVL树、红黑树等。
- 图(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#中的简单实现:
- 冒泡排序(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; | |
| } | |
| } | |
| } | |
| } |
- 选择排序(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; | |
| } | |
| } |
- 插入排序(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; | |
| } | |
| } |
- 快速排序(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#中,数据结构是用于组织和管理数据的方式,以便更有效地进行数据的存储、访问和操作。数据结构对于算法的性能和设计至关重要,因为它们决定了数据如何在内存中布局以及如何与算法进行交互。C#提供了许多内置的数据结构…...
Redis实现秒杀
前期准备 缓存选择考虑 Redis和Redis Cluster(分布式版本),是一个分布式缓存系统。其支持多种数据结构,也支持MQ。Redis在性能上做了大量优化。因此使用Redis或者Redis Cluster就可以轻松实现一个强大的秒杀系统。 用Redis的这…...
4 scala集合-Map
和 Java 一样,Scala 也有表示键值对(Key-Value)集合的 Map 数据结构。同样,Map 也分不可变和可变,不可变需要使用类 scala.collection.mutable.Map。 1 不可变 Map 可以使用以下语法定义不可变 Map 对象 val/var ma…...
QT 对象树模型
QObject是Qt里边绝大部分类的根类 QObject对象之间是以对象树的形式组织起来的。 当两个QObject(或子类)的对象建立了父子关系的时候。子对象就会加入到父对象的一个成员变量叫children(孩子)的list(列表)…...
ubuntu快速安装miniconda
ubuntu快速安装miniconda 环境 ubuntu.22.04 显卡 RTX 3050 关于选择Miniconda还是Anaconda的问题,Anaconda安装包比较大,耗时比较长,如果你是绝对的初学者,选择Anaconda会比较稳妥一些;否则建议你还是选择Miniconda安…...
阿里云游戏服务器多少钱一年?
阿里云游戏服务器租用价格表:4核16G服务器26元1个月、146元半年,游戏专业服务器8核32G配置90元一个月、271元3个月,阿里云服务器网aliyunfuwuqi.com分享阿里云游戏专用服务器详细配置和精准报价: 阿里云游戏服务器租用价格表 阿…...
小游戏和GUI编程(7) | SimpleNN 界面源码解析
小游戏和GUI编程(7) | SimpleNN 界面源码解析 0. 简介 SimpleNN 是 AdamYuan 在高中一年级时用 1 天时间写出来的简易 CNN, 使用 SFML 做 UI, 用于交互式输入手写数字,这个数字被训练好的 CNN 网络执行推理得到识别结果, 它的运行效果如下: 这一篇我们…...
c++设计模式之代理模式
作用 代理模式主要用于,通过代理类,来控制实际对象的访问权限 案例 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;中间的百分比数字逐渐消失,即透明度 opacity 从 1 到 0;背景图片从模糊变为清晰,滤镜 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之间的区别
前言 大家好,我是chowley,在我之前的面试中,遇到过这样一个问题:Exception和Error之间有什么区别?今天我就来好好地总结一下! 主体 在Java编程中,Exception和Error都是Java中的可抛出对象&am…...
【RabbitMQ(一)】:基本介绍 | 配置安装与快速入门
应该是新年前最后一篇博客了,明天浅浅休息一下,提前祝大家新年快乐捏!😊😊😊 01. 基础理解 1.1 同步调用和异步调用 👉 同步调用 的时候调用者会 阻塞 等待被调用函数或方法执行完成ÿ…...
ElasticSearch之search API
写在前面 本文看下查询相关内容,这也是我们在实际工作中接触的最多的,所以有必要好好学习下! 1:查询的分类 主要分为如下2类: 1:基于get查询参数的URI search 2:基于post body的request body search&am…...
07-Java桥接模式 ( Bridge Pattern )
Java桥接模式 摘要实现范例 桥接模式(Bridge Pattern)是用于把抽象化与实现化解耦,使得二者可以独立变化 桥接模式涉及到一个作为桥接的接口,使得实体类的功能独立于接口实现类,这两种类型的类可被结构化改变而互不影…...
golang集成sentry: go-redis
网上没有找到go-redis集成sentry的库, 所以我简单实现了一个 代码: https://github.com/Shujie-Tan/go-redis-sentry 使用方法: import (redis_sentry "github.com/Shujie-Tan/go-redis-sentry" ) rdb : redis.NewClient(&re…...
用EXCEL从地址(上海)中提取各区(浦东新区等区)信息
背景: 朋友工作需要经常用EXCEL把各上海用户收货地址中的区提取出来,之前一直手动处理,希望我帮忙用EXCEL公式直接提取处理。 数据样式: 中国上海市浦东新区A小区 上海徐汇区B小区 中国,上海,浦东新区&a…...
关于在分布式环境中RVN和使用场景的介绍3
简介 在《关于在分布式环境中RVN和使用场景的介绍2》和《关于在分布式环境中RVN和使用场景的介绍1》中我们介绍了RVN的概念和在一些具体用例中的使用。在本文中我们讨论一下在分布式环境中使用RVN需要注意的问题。 问题 我们在收到一条待处理的事件时,需要检查该…...
计算最小公倍数math.lcm()
【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 计算最小公倍数 math.lcm() 请问以下代码输出的结果是? import math print("【执行】math.lcm(2, 4)") print(math.lcm(2, 4)) print("【执行】math.lcm(1, 2, 3…...
VUE SEO 几种方案经典面试题
1、SSR服务器渲染 Vue.js 是构建客户端应用程序的框架。默认情况下,可以再浏览器中输出Vue组件,进行生成DOM和操作DOM。然而,也可以将同一个组件渲染未服务器端的HTML字符串,将它们直接发送到浏览器,最后将这些静态标…...
Python和VBA批量提取Word中的表格
表格在word文档中常见的文档元素之一。操作word文件时有时需要提取文件中多个表格的内容到一个新的文件,甚至有时还会要提取题注信息。 今天,给大家分享两种批量提取文档中表格的两种方法,分别是VBA法和Python法两种。 一、VBA法提取word中…...
Pearcleaner:macOS应用彻底清理的终极免费解决方案
Pearcleaner:macOS应用彻底清理的终极免费解决方案 【免费下载链接】Pearcleaner A free, source-available and fair-code licensed mac app cleaner 项目地址: https://gitcode.com/gh_mirrors/pe/Pearcleaner 你是否曾经遇到过这样的烦恼:在Ma…...
Sunshine游戏串流实战手册:构建你的跨平台游戏共享生态系统
Sunshine游戏串流实战手册:构建你的跨平台游戏共享生态系统 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine 你是否曾想过在客厅大屏电视上畅玩书房电脑里的3A大作&…...
三分钟搞定B站缓存视频:m4s转MP4的傻瓜式完整教程
三分钟搞定B站缓存视频:m4s转MP4的傻瓜式完整教程 【免费下载链接】m4s-converter 一个跨平台小工具,将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 你是不是也遇到过这样的烦恼&#…...
告别Excel!用Python复现地理探测器,手把手教你分析空间数据(附完整代码)
告别Excel!用Python复现地理探测器,手把手教你分析空间数据(附完整代码) 空间数据分析在地理信息科学、生态学和城市规划等领域扮演着关键角色。传统的地理探测器分析往往依赖Excel工具包,但这种方式存在诸多限制&…...
乡村智慧民宿系统|提质增收!巨有科技打造乡村旅居新模式
乡村旅居、民宿康养已经成为乡村文旅主流消费趋势。但大量乡村民宿依旧处于散户经营状态,预定混乱、管控松散、对账困难、同质化严重。巨有科技贴合乡村民宿分散、小规模、本土化的特点,搭建智慧民宿管理系统,用数字化手段规范经营、优化体验…...
可定制尺寸的工业烤盘公司
江苏台烁是专注为大中型食品生产企业提供可定制尺寸全品类工业烤盘的专业厂商,核心竞争优势为全尺寸高精度定制能力搭配智能生产体系,可提供节能耐用、适配产线的工业化烘焙器具解决方案。核心优势与关键数据生产与资质基础:拥有4.8万㎡智能工…...
30+输入法词库互转:一站式零门槛解决方案真的存在吗?
30输入法词库互转:一站式零门槛解决方案真的存在吗? 【免费下载链接】imewlconverter ”深蓝词库转换“ 一款开源免费的输入法词库转换程序 项目地址: https://gitcode.com/gh_mirrors/im/imewlconverter 你是否曾因更换输入法而不得不放弃多年积…...
新手教程使用curl命令一分钟测试Taotoken的OpenAI兼容API
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 新手教程:使用curl命令一分钟测试Taotoken的OpenAI兼容API 本文面向刚获取Taotoken API Key的开发者,目标是…...
TPS5430玩点不一样的:15V输入如何生成一个干净的-12V电源?电路设计与极性电容防炸指南
TPS5430负压生成实战:从15V到-12V的电路设计精要 在模拟电路设计中,双电源供电系统(如12V)是音频设备、运算放大器和高精度ADC的常见需求。然而,当系统仅提供单路正电压输入时,如何高效生成稳定的负电压轨成…...
LabVIEW编程整洁之道:提升代码可读性与可维护性的实战技巧
1. 项目概述:从“能用”到“好用”的进阶之路在LabVIEW这个图形化编程环境里摸爬滚打十几年,我见过太多工程师能把功能做出来,但做出来的程序却像一团乱麻——前面板控件堆叠、程序框图连线交错、结构嵌套深不见底。这样的程序,别…...
