百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

C#中常用的数据结构

liuian 2025-08-01 18:41 3 浏览

写在前面

最近在使用.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#开发程序,语法不同而已。 关键是编程思想和具体业务, 使用那种语言倒是无所谓。

相关推荐

前端开发为什么需要Promise

一、引言在Web前端开发中,异步操作是绕不开的话题。随着用户对网页交互性和响应速度要求的不断提高,开发者们不得不处理越来越多的异步任务,如数据获取、文件读写等。本文旨在探讨Promise作为现代Jav...

『React』组件副作用,useEffect讲解

在React开发中,有时候会听到“副作用”这个词。特别是用到useEffect这个Hook的时候,官方就明确说它是用来处理副作用的。那什么是副作用?为什么我们要专门管控它?今天就聊聊Re...

图解 Promise 实现原理(一):基础实现

作者:孔垂亮转发链接:https://mp.weixin.qq.com/s/UNzYgpnKzmW6bAapYxnXRQ前言很多同学在学习Promise时,知其然却不知其所以然,对其中的用法理解不...

C#实现归并排序与快速排序

字数914,阅读大约需5分钟C#实现归并排序与快速排序以下是使用C#实现的归并排序和快速排序算法代码:usingSystem;usingSystem.Collections.Gener...

C#.NET Newtonsoft.Json 详解

简介Newtonsoft.Json(又称Json.NET)是.NET生态中最流行的JSON序列化/反序列化库,支持.NETFramework、.NETCore、Mono、Xamarin...

C# - 类文件构成,C#基本语法,Console属性与方法 007

类文件(.cs)构成类文件主要分为引用命名空间与自己项目的命名空间1)引用命名空间主要是引用类库,分为内部(.Net类库与解决方案内其他项目的命名空间)外部(引用别人的命名空间),之前说过类库的...

不要过度使用列表(List): C# 数据结构

编程中的每一个决定都会对性能和清晰度产生无声的影响。在C#中,这样重要的选择之一就是选择正确的数据结构。数据结构是基础支柱。这些结构是数据生存、呼吸和交互的地方,决定了代码的效率和可读性。但...

C# 编程语言 31-40个经典案例

案例31:LINQ查询学生成绩排序说明:演示如何使用LINQ查询并排序数据集合。usingSystem;usingSystem.Collections.Generic;usingSyst...

C#中常用的数据结构

写在前面最近在使用.net开发一些程序。它使用的编程语言是C#。我们来看一下它的常用的数据结构有哪些。常用数据结构C#中常见的数据结构:1数组(Array):用于存储固定大小的同类型元素集合...

C# 编程10个经典案例

C#是微软推出的一门现代化、面向对象的高级编程语言,在桌面应用、Web、移动、游戏和云计算等开发领域广泛应用。本篇文章为广大程序员整理了50个必须收藏的经典C#编程案例,助你提升实战能力。案...

C# 动态数组(ArrayList)

动态数组(ArrayList)代表了可被单独索引的对象的有序集合。它基本上可以替代一个数组。但是,与数组不同的是,您可以使用索引在指定的位置添加和移除项目,动态数组会自动重新调整它的大小。它也允许在...

c#集合排序

在C#中,集合排序是一种常见的操作,它可以帮助我们对集合中的元素进行排序。C#中提供了多种集合排序方法,包括Array.Sort、List.Sort、SortedList和SortedSet等。下面分...

c#学习手册 (苏素芳等) 高清PDF版

《c#学习手册》以初学者为核心,全面介绍了使用c#语言进行程序开发的各种技术。在内容排列上由浅入深,让读者循序渐进地掌握编程技术;在内容讲解上结合丰富的图解和形象的比喻,帮助读者理解“晦涩难懂”的技术...

C#中的数组探究与学习

C#中的数组一般分为:①.一维数组。②.多维数组,也叫矩形数组。③.锯齿数组,也叫交错数组。一.数组定义:数组是一种聚合数据类型,它是将具有相同类型的若干变量有序地组织在一起的集合,是最基本的数据结构...

C# 12最新特性解析:代码还能这样写?!微软工程师都惊呆了

在C#的持续进化历程中,每一个新版本都宛如一场技术革新的盛宴,C#12更是如此。它所带来的全新特性,不仅刷新了开发者对代码编写方式的认知,甚至连微软工程师们都为之惊叹。今天,就让我们一同深入探索C#...