C#--Linkeddlist类

简介: C#--Linkeddlist类

Linkeddlist是一个C#为我们封装好的类,它的本质是一个可变类型的泛型双向链表,其元素指定前面和后面的元素。

链表的优点是:如果要插入一个元素到链表的中间位置,会非常的快。原因是,如果插入,只需要修改上一个元素的Next与下一个元素的Previous的引用则可。像ArrayList列表中,如果插入,需要移动其后的所有元素。链表的缺点是,链表只能是一个接着一个的访问,这样就要用较长的时间来查找定位位于链表中间的元素。

链表对象有两个类,一个是链表本身,一个是链表节点类LinkedListNode

LinkedListNode被LinkedList类包含,用LinkedListNode类,可以获得元素的上一个与下一个元素的引用

public class LinkedList : ICollection<T>, IEnumerable<T>, ICollection, IEnumerable, ISerializable, IDeserializationCallback{ 类体。。。}

上述可知,LinkedList继承了ICollection, IEnumerable, ICollection, IEnumerable, ISerializable, IDeserializationCallback接口。

LinkedList的继承关系:

public class LinkedList<E>
extends AbstractSequentialList<E>
implements List<E>, Deque<E>, Cloneable, java.io.Serializable

继承了AbstractSequentialList,本身和AbstractList没有什么区别,但是AbstractSequentialList完善了AbstractList中没有的功能,ArrayList继承之AbstractList,而AbstractSequentialList是AbstractList的子类,所以AbstractSequentialList就是对AbstractLIst中没有的功能进行完善。

其中的Cloneable和Serializable和ArrayList一样,都是标记接口,作用是标记可以复制克隆和序列化。

Deque:实现了Collection中的大家庭接口Queue队列接口。说明了它具有双端队列的功能(LinkedLIst和ArrayList的最大区别就是LinkedList实现了Deque接口,使的LinkedList具有了双端队列的功能)

简单介绍一下LinkedList类的方法与属性:

Count 返回链表中的元素个数

First 返回链表中的第一个节点,其返回的类型是一个节点类LinkedListNode,用它可以迭代集合中的其它节点

Last 返回最后一个节点

AddAfter() AddBefore() AddFirst() AddLast()

使用AddXXXX方法,可以在链表中添加元素分别是链表的头部与尾部,还有一个节点的前面与后面

Remove() RemoveFirst() RemoveLast() First与Last分别删除链表的头部元素与尾表元素 ,Remove是删除指定的一个匹配对像

Clear()清除所有的元素

Contains() 搜索一个元素,如果找到返回TRUE找不到返回FALSE

Find() 从链表头开始找一个元素,并返回他的节点类,LinkedListNode

FindLast() 与Find()类似,不同的是从尾部来搜

目录
相关文章
|
3月前
|
开发框架 .NET C#
C#|.net core 基础 - 删除字符串最后一个字符的七大类N种实现方式
【10月更文挑战第9天】在 C#/.NET Core 中,有多种方法可以删除字符串的最后一个字符,包括使用 `Substring` 方法、`Remove` 方法、`ToCharArray` 与 `Array.Copy`、`StringBuilder`、正则表达式、循环遍历字符数组以及使用 LINQ 的 `SkipLast` 方法。
104 8
|
4月前
|
存储 C# 索引
C# 一分钟浅谈:数组与集合类的基本操作
【9月更文挑战第1天】本文详细介绍了C#中数组和集合类的基本操作,包括创建、访问、遍历及常见问题的解决方法。数组适用于固定长度的数据存储,而集合类如`List<T>`则提供了动态扩展的能力。文章通过示例代码展示了如何处理索引越界、数组长度不可变及集合容量不足等问题,并提供了解决方案。掌握这些基础知识可使程序更加高效和清晰。
99 2
|
3月前
|
Java 程序员 C#
【类的应用】C#应用之派生类构造方法给基类构造方法传参赋值
【类的应用】C#应用之派生类构造方法给基类构造方法传参赋值
18 0
|
4月前
|
C# 数据安全/隐私保护
C# 一分钟浅谈:类与对象的概念理解
【9月更文挑战第2天】本文从零开始详细介绍了C#中的类与对象概念。类作为一种自定义数据类型,定义了对象的属性和方法;对象则是类的实例,拥有独立的状态。通过具体代码示例,如定义 `Person` 类及其实例化过程,帮助读者更好地理解和应用这两个核心概念。此外,还总结了常见的问题及解决方法,为编写高质量的面向对象程序奠定基础。
42 2
|
5月前
|
C#
C#中的类和继承
C#中的类和继承
50 6
|
5月前
|
Java C# 索引
C# 面向对象编程(一)——类
C# 面向对象编程(一)——类
44 0
|
5月前
|
开发框架 .NET 编译器
C# 中的记录(record)类型和类(class)类型对比总结
C# 中的记录(record)类型和类(class)类型对比总结
|
7月前
|
开发框架 .NET 编译器
程序与技术分享:C#基础知识梳理系列三:C#类成员:常量、字段、属性
程序与技术分享:C#基础知识梳理系列三:C#类成员:常量、字段、属性
47 2
|
7月前
|
C#
C# 版本的 计时器类 精确到微秒 秒后保留一位小数 支持年月日时分秒带单位的输出
这篇2010年的文章是从别处搬运过来的,主要包含一个C#类`TimeCount`,该类有多个方法用于处理时间相关的计算。例如,`GetMaxYearCount`计算以毫秒为单位的最大年数,`GetCurrentTimeByMiliSec`将当前时间转换为毫秒,还有`SecondsToYYMMDDhhmmss`将秒数转换为年月日时分秒的字符串。此外,类中还包括一些辅助方法,如处理小数点后保留一位数字的`RemainOneFigureAfterDot`。
|
7月前
|
存储 安全 C#
C# 类的深入指南
C# 类的深入指南