C#中常用的数据结构
liuian 2025-08-01 18:41 29 浏览
写在前面
最近在使用.net 开发一些程序。 它使用的编程语言是C#。 我们来看一下它的常用的数据结构有哪些。
常用数据结构
C# 中常见的数据结构:
1数组 (Array):用于存储固定大小的同类型元素集合。
2列表 (List):动态大小的数组,可以随时添加或删除元素。
3链表 (LinkedList):由节点组成的集合,每个节点包含对下一个节点的引用,适合频繁插入和删除操作。
4集合 (HashSet):不允许重复元素的集合,使用哈希表实现,适合快速查找。
5字典 (Dictionary<TKey, TValue>):键值对集合,使用哈希表实现,适合根据键快速查找值。
6队列 (Queue):先进先出(FIFO)的数据结构,适合需要顺序处理的场景。
7栈 (Stack):先进后出(LIFO)的数据结构,适合后进先处理的场景。
8堆 (Heap):通常通过 PriorityQueue<TElement, TPriority> 实现,用于优先级队列。
9图 (Graph):可以使用邻接表或邻接矩阵表示,用于表示节点及其连接关系。
10集合 (SortedSet):自动排序且不允许重复元素的集合。
这些数据结构各有特点,适用于不同的场景和需求。在选择数据结构时,应根据具体情况考虑时间复杂度、空间复杂度和操作的频率等因素。
代码示例
using System;
using System.Collections.Generic;
class Program
{
static void Main()
{
// 1. 数组 (Array)
int[] scores = { 85, 90, 78, 92, 88 };
Console.WriteLine("学生成绩:");
foreach (var score in scores)
{
Console.WriteLine(score);
}
// 2. 列表 (List<T>)
List<string> students = new List<string>();
students.Add("Alice");
students.Add("Bob");
Console.WriteLine("\n学生名单:");
foreach (var student in students)
{
Console.WriteLine(student);
}
// 3. 链表 (LinkedList<T>)
LinkedList<string> playlist = new LinkedList<string>();
playlist.AddLast("Song A");
playlist.AddLast("Song B");
Console.WriteLine("\n播放列表:");
foreach (var song in playlist)
{
Console.WriteLine(song);
}
// 4. 集合 (HashSet<T>)
HashSet<string> interests = new HashSet<string>();
interests.Add("Music");
interests.Add("Sports");
interests.Add("Music"); // 不会添加重复的 "Music"
Console.WriteLine("\n兴趣标签:");
foreach (var interest in interests)
{
Console.WriteLine(interest);
}
// 5. 字典 (Dictionary<TKey, TValue>)
Dictionary<int, string> studentDict = new Dictionary<int, string>();
studentDict.Add(1, "Alice");
studentDict.Add(2, "Bob");
Console.WriteLine("\n学生字典:");
foreach (var entry in studentDict)
{
Console.WriteLine(#34;ID: {entry.Key}, 姓名: {entry.Value}");
}
// 6. 队列 (Queue<T>)
Queue<string> queue = new Queue<string>();
queue.Enqueue("Customer 1");
queue.Enqueue("Customer 2");
Console.WriteLine("\n排队服务:");
while (queue.Count > 0)
{
Console.WriteLine(#34;服务: {queue.Dequeue()}");
}
// 7. 栈 (Stack<T>)
Stack<string> backStack = new Stack<string>();
backStack.Push("Page 1");
backStack.Push("Page 2");
Console.WriteLine("\n浏览器后退功能:");
while (backStack.Count > 0)
{
Console.WriteLine(#34;后退到: {backStack.Pop()}");
}
// 8. 堆 (Heap)
PriorityQueue<string, int> taskQueue = new PriorityQueue<string, int>();
taskQueue.Enqueue("Task A", 2); // 优先级 2
taskQueue.Enqueue("Task B", 1); // 优先级 1
Console.WriteLine("\n任务处理顺序:");
while (taskQueue.Count > 0)
{
var task = taskQueue.Dequeue();
Console.WriteLine(#34;处理: {task}");
}
// 9. 图 (Graph)
Dictionary<string, List<string>> graph = new Dictionary<string, List<string>>();
graph["Alice"] = new List<string> { "Bob", "Charlie" };
graph["Bob"] = new List<string> { "Alice", "David" };
Console.WriteLine("\n社交网络图:");
foreach (var user in graph)
{
Console.WriteLine(#34;{user.Key} 的好友: {string.Join(", ", user.Value)}");
}
// 10. 集合 (SortedSet<T>)
SortedSet<string> sortedInterests = new SortedSet<string>();
sortedInterests.Add("Music");
sortedInterests.Add("Sports");
sortedInterests.Add("Art");
Console.WriteLine("\n排序的兴趣标签:");
foreach (var interest in sortedInterests)
{
Console.WriteLine(interest);
}
}
}代码说明:
- 数组、列表、链表、集合、字典、队列、栈、堆、图、集合的示例代码均包含在一个主程序中。
- 每个数据结构都包含了初始化、添加元素和遍历的操作。
- 输出结果将显示在控制台上,可以清楚地看到每种数据结构的内容。
你可以将上述代码复制到 C# 开发环境(如 Visual Studio 或 .NET CLI)中运行。
写在最后
对于现代语言, 提供基本数据结构的类库是标配。语言只是实现目标的工具。 熟悉一种语言, 换另外一种语言可以很快上手。 我之前做了10年的java,现在使用C#开发程序,语法不同而已。 关键是编程思想和具体业务, 使用那种语言倒是无所谓。
- 上一篇:C# 编程10个经典案例
- 下一篇:C# 编程语言 31-40个经典案例
相关推荐
- 磁盘不相邻怎么扩展卷(磁盘分区不相邻)
-
要扩展不相邻的磁盘,可以使用磁盘扩展技术,如磁盘阵列(RD)或逻辑卷管理(LVM)。RAID可以将多个磁盘组合成一个逻辑卷,提供更大的存储空间。LVM允许将多个物理卷组合成一个逻辑卷组,并在其中创建逻...
- cad2018永久激活密钥(cad 2018激活)
-
1、首先打开未激活的CAD软件,点击输入序列号。2、选择我同意后进入下一步。然后再点击界面右下角的激活。3、然后输入序列号:666-69696969和产品密钥:001J1。4、然后在界面内点选选择...
- 文件管理应用(文件管理应用同意怎么设置)
-
推荐文件极客App,免费下载,无广告无内购,功能强大。文件极客app是一款强大的本地、网络文件、iCloud文件共享管理专家,专注于iOS文件一体化管理。在文件极客里面,我们可以通过简单的拖动操作...
- ghost64下载(ghost64下载)
-
方法/步骤分步阅读1/4登陆账号首先进入AppStore,然后登陆美区id账号。2/4搜索点击顶部的搜索栏进入搜索页面。3/4查找结果在搜索结果中找到theghost,点击进入详情页面。4/4下载安...
- 一般家庭买什么电脑好(不懂电脑的人建议买联想吗)
-
家庭在使用电脑时,要根据自己的需求来选择电脑。目前电脑主要有两种,一种是笔记本,一种是台式机。1、如果是经常出门办公,比如经常出差需要带电脑,作为家庭在选择电脑时,这时由于自己经常出差带电脑,就要选择...
- 云电脑软件哪个好用(云电脑好用的)
-
达龙云电脑在网络环境良好的情况下,操作起来非常流畅。另外,延迟也不高,这点因该说云电脑控制的非常好。云电脑还支持移动设备,安卓、IOS平台都得到了支持。玩家们可以通过在手机端连接云电脑之后就能在手机上...
- 笔记本电脑如何连接无线wifi
-
要连接笔记本电脑到WiFi,首先确保你的笔记本电脑有无线网卡,并且WiFi已经开启。在电脑桌面右下角的WiFi图标处点击鼠标右键,选择“打开网络和Internet设置”,然后点击“WiFi”,在可用网...
- gho文件安装win10系统方法(gho文件怎么重装系统)
-
不建议这么操作,如果真的要复制,也是很麻烦的,首先要删除win10里面所有的驱动,注意是所有的,然后关机,注意不能重启进入系统,否则又要重新再来,其次找个U盘pe启动盘或者启动光盘,在开机进入pe系统...
- 下载163免费邮箱(免费下载网易邮箱163)
-
第一步:首先,我们手机里要有一个浏览器,小编比较用UC浏览器,当然可以用手机都是自带网页浏览器的,我这边的手机下载网易邮箱第二步:打开UC浏览器或者带浏览器,我们在地址栏上直接输入最新网易邮箱下载安装...
- windows microsoft(windows microsoft store加载不出)
-
电脑开机时出现MicrosoftWindows遇到意外错误,可以尝试用最后一次正确配置来恢复一下。1、重启电脑。2、在电脑显示完硬件信息之后,进入windows界面之前,按F8键。3、在出现的选项菜单...
- 不读u盘的解决办法(不读u盘怎么回事)
-
u盘在电脑里读不出来,出现这种情况,可以用以下方法解决:1、判断U盘是否已经正确插入USB接口,你可以拔下来换个插口试试。2、如果已经启用了USB设备但运行不正常,解决办法为在设备管理器中删除“通用...
- win11怎么激活(win11怎么激活office)
-
目前,Windows11的永久激活方法还没有被公开或者确认。不过,你可以尝试以下几种方法来激活Windows11:使用数字许可证:如果你的电脑已经安装了Windows10并且已经激活,那么你可以...
- 苹果恢复出厂设置(苹果恢复出厂设置还能恢复数据吗)
-
首先打开手机上面的“设置”功能,进入手机的系统设置。进入手机的设置后,选择“通用"。进入通用之后,往下滑动页面,在页面的最下方可以看到“还原”的选项,点击进入。进入还原之后,有多个还原选项,我...
- 一周热门
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
