C#中提供的多种集合类以及适用场景

在 C# 中,有多种集合类可供使用,它们分别适用于不同的场景,部分代码示例提供了LeetCode相关的代码应用。

1. 数组(Array)

  • 特点
    • 固定大小:在创建数组时需要指定其长度,之后无法动态改变。
    • 连续存储:数组元素在内存中是连续存储的,因此可以通过索引快速访问元素,访问时间复杂度为 O(1)。
    • 类型固定:数组中的所有元素必须是相同类型。
  • 示例代码
  int[] numbers = new int[5] { 1, 5, 2, 3, 4 };numbers[0] = 1;//updateint firstNumber = numbers[0];int lastNumber = numbers[numbers.Length - 1];Array.Sort(numbers);//排序

LeetCode: 106. 从中序与后序遍历序列构造二叉树 - 力扣(LeetCode)

public TreeNode BuildTree(int[] inorder, int[] postorder)
{if (inorder.Length == 0 || postorder.Length == null) return null;int rootValue = postorder.Last();TreeNode root = new TreeNode(rootValue);int delimiterIndex = Array.IndexOf(inorder, rootValue);root.left = BuildTree(inorder.Take(delimiterIndex).ToArray(), postorder.Take(delimiterIndex).ToArray());root.right = BuildTree(inorder.Skip(delimiterIndex + 1).ToArray(), postorder.Skip(delimiterIndex).Take(inorder.Length - delimiterIndex - 1).ToArray());return root;
}

2. 动态数组(List<T>)

  • 特点
    • 动态大小:可以根据需要动态添加或删除元素,无需预先指定大小。
    • 连续存储:内部使用数组实现,元素在内存中连续存储,支持通过索引快速访问,访问时间复杂度为 O(1)。
    • 类型安全:泛型集合,只能存储指定类型的元素。
  • 示例代码
List<int> numberList = new List<int>();
numberList.Add(1);
int firstElement = numberList[0];

3. 链表(LinkedList<T>)

  • 特点
    • 动态大小:可以动态添加或删除元素。
    • 非连续存储:元素在内存中不连续存储,每个元素包含一个指向前一个元素和后一个元素的引用。
    • 插入和删除效率高:在链表的任意位置插入或删除元素的时间复杂度为 O(1),但随机访问效率低,时间复杂度为O(n) 。
  • 示例代码
            LinkedList<int> numberLinkedList = new LinkedList<int>();numberLinkedList.AddLast(1);numberLinkedList.AddFirst(2);numberLinkedList.AddFirst(3);numberLinkedList.Remove(1);numberLinkedList.RemoveFirst();numberLinkedList.RemoveLast();int count=numberLinkedList.Count;bool isContains= numberLinkedList.Contains(3);

4. 栈(Stack<T>)

  • 特点
    • 后进先出(LIFO):最后添加的元素最先被移除。
    • 动态大小:可以动态添加或删除元素。
    • 插入和删除操作快:入栈(Push)和出栈(Pop)操作的时间复杂度为O(1) 。
  • 示例代码
            Stack<int> numberStack = new Stack<int>();numberStack.Push(1);// Removes and returns the object at the top of the System.Collections.Generic.Stack`1.int topElement = numberStack.Pop();// Returns the object at the top of the System.Collections.Generic.Stack`1 without removing it.topElement = numberStack.Peek(); int count = numberStack.Count;

LeetCode: 144. 二叉树的前序遍历

/*** Definition for a binary tree node.* public class TreeNode {*     public int val;*     public TreeNode left;*     public TreeNode right;*     public TreeNode(int val=0, TreeNode left=null, TreeNode right=null) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
public class Solution {public IList<int> PreorderTraversal(TreeNode root) {var result = new List<int>();if (root == null) return result;Stack<TreeNode> treeNodes = new Stack<TreeNode>();// 栈是先进后出。 中序遍历是:中--》 左--》右treeNodes.Push(root);while (treeNodes.Count > 0){TreeNode current = treeNodes.Pop();result.Add(current.val);// 中if (current.right != null)// 右{treeNodes.Push(current.right);}if (current.left != null)// 左{treeNodes.Push(current.left);}}return result;}
}

5. 队列(Queue<T>)

  • 特点
    • 先进先出(FIFO):最先添加的元素最先被移除。
    • 动态大小:可以动态添加或删除元素。
    • 插入和删除操作快:入队(Enqueue)和出队(Dequeue)操作的时间复杂度为 O(1)。
  • 示例代码
          Queue<int> numberQueue = new Queue<int>();numberQueue.Enqueue(1);// Removes and returns the object at the beginning of the System.Collections.Generic.Queue`1.int firstElement = numberQueue.Dequeue();//Returns the object at the beginning of the System.Collections.Generic.Queue`1 without removing it.numberQueue.Peek();int count = numberQueue.Count;

LeetCode: 102. 二叉树的层序遍历 - 力扣(LeetCode) 

/*** Definition for a binary tree node.* public class TreeNode {*     public int val;*     public TreeNode left;*     public TreeNode right;*     public TreeNode(int val=0, TreeNode left=null, TreeNode right=null) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
public class Solution {public IList<IList<int>> LevelOrder(TreeNode root) {var result = new List<IList<int>>();Queue<TreeNode> queue = new ();if (root != null) queue.Enqueue(root);while (queue.Count>0){var row=new List<int>();int count=queue.Count;// 需要事先记录Queue的Count,不能直接依靠Queue本身for (int i=0; i < count; i++){var currentNode=queue.Dequeue();row.Add(currentNode.val);if (currentNode.left != null) queue.Enqueue(currentNode.left);if (currentNode.right != null) queue.Enqueue(currentNode.right);}result.Add(row);}return result;}
}

6. 哈希集合(HashSet<T>)

  • 特点
    • 唯一元素:集合中不允许有重复的元素。
    • 无序:元素在集合中没有特定的顺序。
    • 快速查找:插入、删除和查找操作的平均时间复杂度为O(1) 。
  • 示例代码
      HashSet<int> numberHashSet = new HashSet<int>();numberHashSet.Add(1);bool isAddSuccess = numberHashSet.Add(1);// falsebool containsOne = numberHashSet.Contains(1);// true

如LeetCode:491. 非递减子序列

public class Solution {public IList<IList<int>> FindSubsequences(int[] nums) {var result = new List<IList<int>>();var path = new List<int>();if(nums==null || nums.Length == 0) return result;BackTacking(nums,result,path,0);return result;}private void BackTacking(int[] nums,List<IList<int>> result, List<int> path,int startIndex){if (path.Count>=2) result.Add(new List<int>(path));HashSet<int> used =new HashSet<int>();for (int i=startIndex;i<nums.Length;i++){if(path.Count>0 && nums[i]<path[path.Count-1]) continue;bool isUsed=used.Add(nums[i]);// true-添加成功;false-添加失败,证明已经有元素存在了if(!isUsed) continue;// 同一层重复使用path.Add(nums[i]);BackTacking(nums,result,path,i+1);path.RemoveAt(path.Count-1);}}
}

7. 字典(Dictionary<TKey, TValue>)

  • 特点
    • 键值对存储:通过唯一的键来关联对应的值。
    • 快速查找:根据键查找值的平均时间复杂度为  O(1)。
    • 键唯一:字典中的键必须是唯一的,但值可以重复。
  • 示例代码
Dictionary<string, int> scores = new Dictionary<string, int>();
scores.Add("Alice", 90);
int aliceScore = scores["Alice"];

LeetCode: 105. 从前序与中序遍历序列构造二叉树 - 力扣(LeetCode)

/*** Definition for a binary tree node.* public class TreeNode {*     public int val;*     public TreeNode left;*     public TreeNode right;*     public TreeNode(int val=0, TreeNode left=null, TreeNode right=null) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
public class Solution {public TreeNode BuildTree(int[] preorder, int[] inorder){if (preorder == null || inorder == null){return null;}/*前序遍历   根   左子树 右子树中序遍历   左子树 根   右子树*/if (preorder.Length != inorder.Length){return null;}Dictionary<int, int> keyMap = new Dictionary<int, int>();for (int i = 0; i < inorder.Length; i++){keyMap.Add(inorder[i], i);}return BuildTree(preorder: preorder, keyMap, preleft: 0, preRight: preorder.Length - 1, inLeft: 0, inRight: inorder.Length - 1);}/// <summary>/// /// </summary>/// <param name="preorder"></param>/// <param name="keyMap">用于确定pIndex。Root的Index</param>/// <param name="preleft"></param>/// <param name="preRight"></param>/// <param name="inLeft"></param>/// <param name="inRight"></param>/// <returns></returns>private TreeNode BuildTree(int[] preorder, Dictionary<int, int> keyMap, int preleft, int preRight, int inLeft, int inRight){if (preleft > preRight || inLeft > inRight){return null;}int rootValue = preorder[preleft];TreeNode treeNode = new TreeNode(rootValue);int pIndex = keyMap[rootValue];treeNode.left = BuildTree(preorder, keyMap, preleft: preleft + 1, preRight: pIndex + preleft - inLeft, inLeft, inRight: pIndex - 1);//根据PreOrder去取Left nodetreeNode.right = BuildTree(preorder, keyMap, preleft: pIndex + preleft - inLeft + 1, preRight: preRight, inLeft: pIndex + 1, inRight);//根据inOrder去取Right nodereturn treeNode;}
}

8. 排序集合(SortedSet<T>)

  • 特点
    • 唯一元素:集合中不允许有重复的元素。
    • 有序:元素会根据元素的自然顺序或指定的比较器进行排序。
    • 查找和插入操作:插入、删除和查找操作的时间复杂度为 O(logn)。
  • 示例代码
SortedSet<int> sortedNumbers = new SortedSet<int>();
sortedNumbers.Add(3);
sortedNumbers.Add(1);
// 元素会自动排序,遍历输出为 1, 3
foreach (int number in sortedNumbers)
{Console.WriteLine(number);
}

9. 排序字典(SortedDictionary<TKey, TValue>)

  • 特点
    • 键值对存储:通过唯一的键来关联对应的值。
    • 有序:元素会根据键的自然顺序或指定的比较器进行排序。
    • 查找和插入操作:根据键查找值、插入和删除操作的时间复杂度为  O(logn)。
  • 示例代码
SortedDictionary<string, int> sortedScores = new SortedDictionary<string, int>();
sortedScores.Add("Evan", 38);
sortedScores.Add("Alice", 30);
// 会根据键排序,遍历输出 Alice: 30, Evan: 38
foreach (KeyValuePair<string, int> pair in sortedScores)
{Console.WriteLine($"{pair.Key}: {pair.Value}");
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/23782.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux网络 网络层

IP 协议 协议头格式 4 位版本号(version): 指定 IP 协议的版本, 对于 IPv4 来说, 就是 4. 4 位头部长度(header length): IP 头部的长度是多少个 32bit, 也就是 4 字节&#xff0c;4bit 表示最大的数字是 15, 因此 IP 头部最大长度是 60 字节. 8 位服务类型(Type Of Service):…

Unity百游修炼(1)——FootBall详细制作全流程

一、引言 游玩测试&#xff1a; Football 游玩测试 1.项目背景与动机 背景&#xff1a;在学习 Unity 的过程中&#xff0c;希望通过实际项目来巩固所学知识&#xff0c;同时出于对休闲小游戏的喜爱&#xff0c;决定开发一款简单有趣的小游戏加深自己的所学知识点。 动机&#…

C语言(13)------------>do-while循环

1.do-while循环的语法 我们知道C语言有三大结构&#xff0c;顺序、选择、循环。我们可以使用while循环、for循环、do-while循环实现循环结构。之前的博客中提及到了前两者的技术实现。可以参考&#xff1a; C语言&#xff08;11&#xff09;-------------&#xff1e;while循…

【1】VS Code 新建上位机项目---C#基础语法

VS Code 新建上位机项目---C#基础语法 1 基本概念1.1 准备工具1.2 新建项目2 C#编程基础2.1 命名空间和类2.2 数据类型2.3 控制台输入输出2.3.1 输入输出: write 与 read2.3.2 格式化 : string.Foramt() 与 $2.3.3 赋值与运算2.4 类型转换2.4.1 数值类型之间的转换:(int)2.4…

SQL:DQL数据查询语言以及系统函数(oracle)

SQL Structured Query Language&#xff0c;结构化查询语言, 是一种用于管理和操作关系数据库的标准编程语言。 sql的分类 DQL&#xff08;Data Query Language&#xff09;&#xff1a;数据查询语言 DDL&#xff08;Data Definition Language&#xff09;&#xff1a;数据…

从单片机的启动说起一个单片机到点灯发生了什么下——使用GPIO点一个灯

目录 前言 HAL库对GPIO的抽象 核心分析&#xff1a;HAL_GPIO_Init 前言 我们终于到达了熟悉的地方&#xff0c;对GPIO的初始化。经过漫长的铺垫&#xff0c;我们终于历经千辛万苦&#xff0c;来到了这里。关于GPIO的八种模式等更加详细的细节&#xff0c;由于只是点个灯&am…

提效10倍:基于Paimon+Dolphin湖仓一体新架构在阿里妈妈品牌业务探索实践

1. 业务背景 阿里妈妈品牌广告数据包括投放引擎、下发、曝光、点击等日志&#xff0c;面向运筹调控、算法特征、分析报表、诊断监控等应用场景&#xff0c;进行了品牌数仓能力建设。随着业务发展&#xff0c;基于Lambda架构的数仓开发模式&#xff0c;缺陷日益突出&#xff1a;…

一文详解U盘启动UEFI/Legacy方式以及GPT/MBR关系

对于装系统的老手而说一直想研究一下装系统的原理&#xff0c;以及面对一些问题时的解决思路&#xff0c;故对以前的方法进行原理上的解释&#xff0c;主要想理解其底层原理。 引导模式 MBR分区可以同时支持UEFI和Legacy引导&#xff0c;我们可以看一下微pe制作的启动盘&#…

基于Docker的前端环境管理:从开发环境到生产部署的实现方案

# 基于Docker的前端环境管理&#xff1a;从开发环境到生产部署的实现方案 简介及前端开发环境挑战 简介 是一种容器化平台&#xff0c;可以将应用程序及其依赖项打包为一个容器&#xff0c;提供一种轻量级、可移植的环境。它能够简化开发、部署和运维的流程&#xff0c;提高…

连锁管理系统的五大核心设计及 PHP 源码分享

在当今竞争激烈的连锁商业领域&#xff0c;高效的管理系统是企业脱颖而出的关键。商淘云连锁管理系统凭借其卓越的功能和灵活的架构&#xff0c;为连锁企业提供了强大的运营支持。在这里详细介绍其五大核心设计&#xff0c;并分享相关的 PHP 源码示例。 一、总部进销存管理 &a…

C语言基本知识------指针(4)

1. 回调函数是什么&#xff1f; 回调函数就是⼀个通过函数指针调用的函数。 如果你把函数的指针&#xff08;地址&#xff09;作为参数传递给另⼀个函数&#xff0c;当这个指针被⽤来调⽤其所指向的函数 时&#xff0c;被调⽤的函数就是回调函数。 void qsort(void base,//指针…

MTK-Android13-包安装器PackageInstaller 静默安装实现

目的 我们最终是为了搞明白安装的整个流程。一方面通过安卓系统自带的包安装器来了解PMS 安装流程&#xff1b;另一方面熟悉框架层Framework 针对Android apk 安装流程。 前两篇文章分析了PackagerInstaller 安装流程。 Android13-包安装器PackageInstaller-之apk安装跳转 An…

qt-C++笔记之创建和初始化 `QGraphicsScene` 和 `QGraphicsView` 并关联视图和场景的方法

qt-C++笔记之创建和初始化 QGraphicsScene 和 QGraphicsView 并关联视图和场景的方法 code review! 参考笔记 1.qt-C++笔记之创建和初始化 QGraphicsScene 和 QGraphicsView 并关联视图和场景的方法 2.qt-C++笔记之QGraphicsScene和 QGraphicsView中setScene、通过scene得到vie…

《一起打怪兽吧》——自制一款Python小游戏

《一起消灭怪兽吧》——在深夜的屏幕前&#xff0c;你是指引光明的勇者。键盘化作利剑&#xff0c;用方向键在像素战场游走&#xff0c;发射吧&#xff0c;每次击杀都有代码绽放的烟火。这款由Python与Pygame铸就的小游戏&#xff0c;让0与1的世界生长出童真的浪漫。 文章目录…

IDEA中查询Maven项目的依赖树

在Maven项目中&#xff0c;查看项目的依赖树是一个常见的需求&#xff0c;特别是当你需要了解项目中直接或间接依赖了哪些库及其版本时。你可以通过命令行使用Maven的dependency:tree插件来做到这一点。这个命令会列出项目中所有依赖的树状结构。 打开idea项目的终端&#xff…

Maven——Maven开发经验总结(1)

摘要 本文总结了 Maven 开发中的多个关键经验&#xff0c;包括如何根据版本号决定推送到 releases 或 snapshots 仓库&#xff0c;如何在构建过程中跳过测试&#xff0c;父项目如何控制子项目依赖版本&#xff0c;父项目依赖是否能传递到子项目&#xff0c;如何跳过 Maven dep…

05. Springboot admin集成Actuator(一)

目录 1、前言 2、Actuator监控端点 2.1、健康检查 2.2、信息端点 2.3、环境信息 2.4、度量指标 2.5、日志文件查看 2.6、追踪信息 2.7、Beans信息 2.8、Mappings信息 3、快速使用 2.1、添加依赖 2.2、添加配置文件 2.3、启动程序 4、自定义端点Endpoint 5、自定…

【GESP】C++二级模拟 luogu-b3995, [GESP 二级模拟] 小洛的田字矩阵

GESP二级模拟题&#xff0c;多层循环、分支语句练习&#xff0c;难度★✮☆☆☆。 题目题解详见&#xff1a;https://www.coderli.com/gesp-2-luogu-b3995/ 【GESP】C二级模拟 luogu-b3995, [GESP 二级模拟] 小洛的田字矩阵 | OneCoderGESP二级模拟题&#xff0c;多层循环、分…

uniapp在app下使用mqtt协议!!!支持vue3

什么&#xff1f;打包空白&#xff1f;分享一下我的解决方法&#xff01; 第一步 找大师算过了&#xff0c;装4.1版本运气好&#xff01; 所以根目录执行命令… npm install mqtt4.1.0第二步 自己封装一个mqtt文件方便后期开坛做法&#xff01; // utils/mqtt.js import mqt…

C++程序员内功修炼——Linux C/C++编程技术汇总

在软件开发的宏大版图中&#xff0c;C 语言宛如一座巍峨的高山&#xff0c;吸引着无数开发者攀登探索。而 Linux 操作系统&#xff0c;以其开源、稳定、高效的特性&#xff0c;成为了众多开发者钟爱的开发平台。将 C 与 Linux 相结合&#xff0c;就如同为开发者配备了一把无坚不…