C#中常用的数据结构
liuian 2025-08-01 18:41 35 浏览
写在前面
最近在使用.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个经典案例
相关推荐
- ghostxp32位下载(ghost win7下载32位)
-
你不需要直接加4G的,你再买一条2G同品牌型号内存加上去,组成4G内存就行,不过系统要改为Win764位系统,因为XP只能认3.25G内存,如果你想下载圣安地列斯游戏,并且使用的系统是Window...
- eset nod32 24位激活码(eset激活码生成器)
-
ESETNOD32Antivirus4的激活码是24位的例如M26D-0233-4W9Q-VSSB-D84G-JJJJ或V26D-0243-4W9Q-VSSB-D84G-JGFD(友情提示...
- 鸿蒙系统的优缺点(鸿蒙4.3和5.0哪个好)
-
一、鸿蒙系统的缺点鸿蒙最大的缺点应该就是生态了。鸿蒙系统依赖安卓生态无可厚非,前者毕竟是一款刚刚发布两年的新系统。而安卓,早在几十年前就已经上线,谷歌建设安卓生态也用了十多年的时间。在巨大的时间差面前...
-
- bios怎么格式化c盘(bios格式下怎么彻底格式化电脑)
-
步骤/方式1BIOS没有格式化硬盘的功能。对硬盘进行格式化,首先需要给硬盘分区并分配文件系统,BIOS不支持文件系统的识别,所以也不支持格式化的功能。步骤/方式2早期的计算机系统在BIOS里面曾经有过低级格式化的功能,但是低级格式化只是对硬...
-
2025-12-22 20:05 liuian
- 电脑开机显示屏显示蓝屏(开机后显示器蓝屏)
-
造成电脑蓝屏的原因主要有以下几点。1、电脑使用过度,温度过高过度使用电脑会导致电脑硬件发生损坏,系统超载,内部运算过多,cpu温度急剧升高,会发生系统错误。建议更换散热系统,更新“小风扇”设备,并合...
- 设置无线网密码步骤(如何设置无线网络wifi密码)
-
首先使用已经连接到网络的手机或电脑,在浏览器地址栏输入192.168.1.1或者192.168.0.1;输入管理员账号和密码,两个一般都是输入admin;点击【无线设置】,进入【安全选项】,在输入旧密...
- 下载优酷官方正版(下载优酷官方正版网站)
-
您好,直接打开浏览器或者打开手机的应用商城,然后输入该软件的名称然后搜索即可在搜索结果中下载安装即可,也可以下载一个市场类软件,常见的有安卓市场,机锋市场等,之后使用此款软件下载其他程序。优酷视频...
- iso文件安装器(iso安装程序)
-
不能。苹果手机是不能安装apk格式软件的,apk是安卓系统的安装包格式。通过将APK文件直接传到Android模拟器或Android手机中执行即可安装。apk文件和sis一样,把androidsdk...
-
- 台式电脑重装系统按哪个键进入
-
不同品牌的设备按键是不同的1、如果原来电脑装一键还原软件,装系统时直接在启动画面选择重新恢复系统项即可;2、如需启动光盘或者优盘来重装系统,需要开机按启动热键,选择对应的按键即可调出启动菜单选择界面,在菜单中选择优盘或光驱,按回车,按提示进...
-
2025-12-22 17:55 liuian
- 戴尔笔记本电脑一开机就蓝屏
-
笔记本蓝屏可能是电脑硬盘故障,可以更换一个硬盘尝试。也可能是更新了驱动与修复漏洞补丁,可以进入安全模式将更新的驱动删除。有可能是内存条故障,可以把内存条取下来,用橡皮擦轻轻擦拭金手指,然后用毛刷将内存...
- 优酷路由宝怎么设置(优酷路由宝怎么设置网络)
-
无线连接如果准备用手机、笔记本电脑来设置优酷路由宝,需要先把WAN口,连接宽带网线(宽带猫、光猫);然后手机/笔记本电脑搜索连接到优酷路由宝的WiFi。优酷路由宝的默认WiFi名称是:Youku_开...
- 一键装机软件大全(一键装机下载)
-
1一键装机工具是一种自动化安装计算机操作系统以及常用软件的工具。2使用一键装机工具,需要先准备好需要安装的操作系统镜像和需要安装的软件列表,然后将它们放在一键装机工具所指定的位置。接下来,打开一键...
- home键是什么意思苹果手机(home键是苹果手机哪个键)
-
就是手机屏幕正下方的那个圆形的按钮,就是苹果手机的home键,home键的作用比较大,可以用来设置指纹解锁,单机home键可以返回主屏幕界面,双击home键可以弹出后台应用程序可以进行清楚,还可以通过...
- tplink说明书图片(tp-link路由器说明书步骤图)
-
第一步连接路由器WIFI在手机获取IP地址里找到路由器网关地址,第二步在浏览器地址栏输入路由器网关地址,之后会跳转到路由器管理员登录界面,输入账号密码就可以进入路由后台管理路由,如果提示路由器密码错误...
- 一周热门
- 最近发表
- 标签列表
-
- 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)
