标签:sys ucloud 哈希表 public 语法 obj null 树形结构 count
跟上一篇《数据结构,你还记得吗(上)》目录进行一一对应讲解C#中各种数据结构,以此来提升大家的理解。
多维数组,行和列是固定的:
int[][] arrMore=new int[3][6];
锯齿数组只要在第一个方括号设置行数,每行的个数是可变的。
int[][] jagged=new int[3][];
jagged[0]=new int[2]{1,2};
jagged[1]=new int[6]{1,2,3,4,5,6};
jagged[2]=new int[3]{1,2,3};
Array 类是 C# 中所有数组的基类,它是在 System 命名空间中定义(System.Array)。Array 类提供了各种用于数组的属性和方法。
用方括号声明数组是C#中使用Array类的表示法。在后台使用C#语法,会创建一个派生自抽象基类Array的新类。这样,就可以使用Array类为每个C#数组定义的方法和属性了。
??Array类是一个抽象类,所以不能使用构造函数来创建数组。但除了可以使用C#语法创建数组实例之外,还可以使用静态方法CreateInstance()创建数组。如果事先不知道元素的类型,该静态方法就非常有用,因为类型可以作为Type对象传递给CreateInstance()方法。
例如:
Array arr=Array.CeateInstance(typeof(int),5);
for(int i=0;i<5;i++)
{
arr.SetVaule(i,i);
}
for(int i=0;i<5;i++)
{
int vaule=arr.getVaule(i);
}
羽毛球筒
??堆栈(Stack)代表了一个后进先出的对象集合。当您需要对各项进行后进先出的访问时,则使用堆栈。当您在列表中添加一项,称为推入元素,当您从列表中移除一项时,称为弹出元素。
public class Stack<T> : IEnumerable<T>, ICollection, IEnumerable
public class Stack : ICollection, IEnumerable, ICloneable
属性 | 描述 |
---|---|
Count | 获取 Stack 中包含的元素个数 |
方法 | 描述 |
---|---|
Pop | public virtual object Pop();移除并返回在 Stack 的顶部的对象 |
push | public virtual void Push(object obj);向 Stack 的顶部添加一个对象 |
peek | public virtual object Peek();返回在 Stack 的顶部的对象,但不移除它 |
ToArray | public virtual object[] ToArray();创建数组并将堆栈元素复制到其中 |
Contains | public virtual bool Contains(object obj);判断一个元素是否在栈中 |
Clear | public virtual void Clear();从 Stack 中移除所有的元素。 |
水管子
队列(Queue)代表了一个先进先出的对象集合。当您需要对各项进行先进先出的访问时,则使用队列。当您在列表中添加一项,称为入队,当您从列表中移除一项时,称为出队。
public class Queue : ICollection, IEnumerable, ICloneable
public class Queue<T> : IEnumerable<T>, IEnumerable, IReadOnlyCollection<T>, ICollection
属性 | 描述 |
---|---|
Count | 获取 Queue 中包含的元素个数 |
方法 | 描述 |
---|---|
Clear | public virtual void Clear(); 从 Queue 中移除所有的元素。 |
Contains | public virtual bool Contains( object obj ); 判断某个元素是否在 Queue 中。 |
Dequeue | public virtual object Dequeue();移除并返回在 Queue 的开头的对象。 |
Enqueue | public virtual void Enqueue( object obj ); 向 Queue 的末尾添加一个对象。 |
ToArray | public virtual object[] ToArray();复制 Queue 到一个新的数组中。 |
TrimToSize | public virtual void TrimToSize();设置容量为 Queue 中元素的实际个数。 |
实现方式
public class Node<T>
{
public T Data { set; get; } //数据域,当前结点数据
public Node<T> Next { set; get; } //位置域,下一个结点地址
public Node(T item)
{
this.Data = item;
this.Next = null;
}
public Node()
{
this.Data = default(T);
this.Next = null;
}
}
请转到《数据结构:单链表》查看更详细内容!
??LinkedList
链表在存储元素时,不仅要存储元素的值,还必须存储每个元素的下一个元素和上一个元素的信息。这就是LinkedList
链表的优点是,如果将元素插入到列表的中间位置,使用链表就会很快。在插入一个元素时,只需要修改上一个元素的Next引用和下一个元素的Previous引用,使它们引用所插入的元素。在List
链表的缺点是,链表元素只能一个接一个的访问,这需要较长时间来查找位于链表中间或尾部的元素。
LinkedList
在指定位置插入元素:AddAfter(),AddFirst()和AddLast();
删除指定位置的元素:Remove(),RemoveFirst(),RemoveLast();
搜索:Find(),FindLast()。
菜单树
C#中没有实现树的具体类,一般可以通过自己实现。
结点树包含:父结点(根结点的父结点为null)、子结点(List集合)、数据对象。
请转到《 数据结构:树》查看更详细的内容!
??图状结构简称图,是另一种非线性结构,它比树形结构更复杂。树形结构中的结点是一对多的关系,结点间具有明显的层次和分支关系。每一层的结点可以和下一层的多个结点相关,但只能和上一层的一个结点相关。而图中的顶点(把图中的数据元素称为顶点)是多对多的关系,即顶点间的关系是任意的,图中任意两个顶点之间都可能相关。也就是说,图的顶点之间无明显的层次关系,这种关系在现实世界中大量存在。因此,图的应用相当广泛,在自然科学、社会科学和人文科学等许多领域都有着非常广泛的应用。
c#没有实现图的数据结构,但是可以自己实现,参考如下
请转到《数据结构:图》查看更详细内容!
c#也没有实现字典树,可以自己实现,参考如下
请转到《数据结构:字典树》查看更详细内容!
??Hashtable是System.Collections命名空间提供的一个容器,用于处理和表现类似keyvalue的键值对,其中key通常可用来快速查找,同时key是区分大小写;value用于存储对应于key的值。Hashtable中keyvalue键值对均为object类型,所以Hashtable可以支持任何类型的keyvalue键值对.
using System.Collections;
using System.Collections.Generic;
//添加一个keyvalue键值对:
HashtableObject.Add(key,value);
//移除某个keyvalue键值对:
HashtableObject.Remove(key);
//移除所有元素:
HashtableObject.Clear();
// 判断是否包含特定键key:
HashtableObject.Contains(key);
遍历哈希表需要用到DictionaryEntry Object,代码如下:
for(DictionaryEntry de in ht) //ht为一个Hashtable实例
{
Console.WriteLine(de.Key); //de.Key对应于keyvalue键值对key
Console.WriteLine(de.Value); //de.Key对应于keyvalue键值对value
}
请转到《数据结构:哈希表》查看更详细内容!
综上所述,找了相关的文档之后,发现C#本身没有封装部分数据结构,可能是让大家自己发挥,也可能跟它当初设计的原因有关,因为它不是专们为处理数据而诞生的。真的又是写了一篇小白文,发现写到这里还不够,于是将标题改为《数据结构,你还记得吗(中)》,接下来还要继续《数据结构,你还记得吗(下)》 未完待续!
其他系列的C#数据结构参考《C# 数据结构》
标签:sys ucloud 哈希表 public 语法 obj null 树形结构 count
原文地址:https://www.cnblogs.com/zhan520g/p/10218104.html