C# 单向链表数据结构 (一)
单向链表数据结构是有节点组成,每个节点包含两部分,第一部分为存储数据,
第二部分为指向下一个节点的指针。注意,有两个特色的节点,分别为“头节点”
和“尾节点”,头节点本身没有数据,只存储下一个节点的指针,尾节点只存数据
1 //节点类
public class ListNode
{
public ListNode(int NewValue)
{
Value = NewValue;
}
//前一个
public ListNode Previous;
//后一个
public ListNode Next;
//值
public int Value; }
//链表类
public class Clist
{
public Clist()//构造函数
{
//初始化
ListCountValue = ;
Head = null;
Tail = null;
}
private ListNode Head;//头指针
private ListNode Tail;//尾指针
private ListNode Current;//当前指针
private int ListCountValue;//链表数据的个数
//向尾部添加数据方法
public void Append(int DataValue)
{
ListNode NewNode = new ListNode(DataValue); if (IsNull())//如果头指针为空
{
Head = NewNode;
Tail = NewNode;
}
else
{
Tail.Next = NewNode;
NewNode.Previous = Tail;
Tail = NewNode;
}
Current = NewNode;
ListCountValue += ;//链表个数加 1
}
public void Delete()
{
if (!IsNull())//若为空链表
{
if (!IsBof())//若删除头
{
Head = Current.Next;
Current = Head;
ListCountValue -= ;
return;
}
if (!IsEof())//若删除尾
{
Tail = Current.Previous;
Current = Tail;
ListCountValue -= ;
return;
}
Current.Previous.Next = Current.Next;//若删除中间数据
Current = Current.Previous;
ListCountValue -= ;
return;
}
}
//向后移动一个数据的方法
public void MoveNext()
{
if (!IsEof()) Current = Current.Next;
}
//向前移动一个数据的方法
public void MovePrevious()
{
if (!IsBof()) Current = Current.Previous;
}
//移动到第一个数据方法
public void MoveFrist()
{
Current = Head;
}
//移动到最后一个数据方法
public void MoveLast()
{
Current = Tail;
}
//判断是否为空链表方法
public bool IsNull()
{
if (ListCountValue == )
return true;
return false;
}
//判断是否为到达尾部方法
public bool IsEof()
{
if (Current == Tail)
return true;
return false;
}
//判断是否为到达头部方法
public bool IsBof()
{
if (Current == Head)
return true;
return false;
}
//取得当前结点的值方法
public int GetCurrentValue()
{
return Current.Value;
}
//取得链表的数据个数方法
public int ListCount
{
get { return ListCountValue; }
}
//清空链表方法
public void Clear()
{
MoveFrist();
while (!IsNull())
{
Delete();//若不为空链表,从尾部删除
}
}
//在当前位置前输入数据方法
public void Insert(int DataValue)
{
ListNode NewNode = new ListNode(DataValue);
if (IsNull())
{
Append(DataValue);//为空表,则添加
return;
}
if (IsBof())
{
//为头部插入
NewNode.Next = Head;
Head.Previous = NewNode;
Head = NewNode;
Current = Head;
ListCountValue += ;
return;
}
//中间插入
NewNode.Next = Current;
NewNode.Previous = Current.Previous;
Current.Previous.Next = NewNode;
Current = NewNode;
ListCountValue += ;
}
//进行升序插入方法
public void InsertAscending(int InsertValue)
{
//参数:InsertValue 插入的数据
//为空链表
if (IsNull())
{
//添加
Append(InsertValue);
return;
}
MoveFrist();//移动到头
if ((InsertValue < GetCurrentValue()))
{
Insert(InsertValue);//满足添加,则插入
return;
}
while (true)
{
if (InsertValue < GetCurrentValue())
{
//满足条件,则插入,退出
Insert(InsertValue);
break;
}
if (IsEof())
{//从尾部插入
Append(InsertValue);
break;
}
//移动到下一个指针
MoveNext();
}
} //进行降序插入方法
public void InsertUnAscending(int InsertValue)
{
//参数:InsertValue 插入的数据
//为空链表
if (IsNull())
{
//添加
Append(InsertValue);
return;
}
//移动到头
MoveFrist();
if (InsertValue > GetCurrentValue())
{
//满足条件,则插入,退出
Insert(InsertValue);
return;
}
while (true)
{
if (InsertValue > GetCurrentValue())
{
//满足条件,则插入,退出
Append(InsertValue);
break;
}
if (IsEof())
{
//尾部添加
Append(InsertValue);
break;
}
//移动到下一个指针
MoveNext();
} }
}
C# 单向链表数据结构 (一)的更多相关文章
- 数据结构-单向链表 C和C++的实现
		
数据结构,一堆数据的存放方式. 今天我们学习数据结构中的 链表: 链表的结构: 链表是一种特殊的数组,它的每个元素称为节点,每个节点包括两个部分: 数据域:存放数据,此部分与数组相同 指针域:存放了下 ...
 - Linux C 数据结构 ->单向链表<-(~千金散尽还复来~)
		
之前看到一篇单向链表的博文,代码也看着很舒服,于是乎记录下来,留给自己~,循序渐进,慢慢 延伸到真正的内核链表~(敢问路在何方?路在脚下~) 1. 简介 链表是Linux 内核中最简单,最普通的数据结 ...
 - 数据结构(1) 第一天 算法时间复杂度、线性表介绍、动态数组搭建(仿Vector)、单向链表搭建、企业链表思路
		
01 数据结构基本概念_大O表示法 无论n是多少都执行三个具体步骤 执行了12步 O(12)=>O(1) O(n) log 2 N = log c N / log c N (相当于两个对数进行了 ...
 - Linux C 数据结构 ->单向链表
		
之前看到一篇单向链表的博文,代码也看着很舒服,于是乎记录下来,留给自己~,循序渐进,慢慢 延伸到真正的内核链表~(敢问路在何方?路在脚下~) 1. 简介 链表是Linux 内核中最简单,最普通的数据结 ...
 - C语言 - 基础数据结构和算法 - 单向链表
		
听黑马程序员教程<基础数据结构和算法 (C版本)>,照着老师所讲抄的, 视频地址https://www.bilibili.com/video/BV1vE411f7Jh?p=1 喜欢的朋友可 ...
 - 数据结构——Java实现单向链表
		
结点类: /** * @author zhengbinMac * 一个OnelinkNode类的对象只表示链表中的一个结点,通过成员变量next的自引用方式实现线性表中各数据元素的逻辑关系. */ p ...
 - [置顶] ※数据结构※→☆线性表结构(list)☆============单向链表结构(list single)(二)
		
单向链表(单链表)是链表的一种,其特点是链表的链接方向是单向的,对链表的访问要通过顺序读取从头部开始:链表是使用指针进行构造的列表:又称为结点列表,因为链表是由一个个结点组装起来的:其中每个结点都有指 ...
 - 数据结构——求单向链表的倒数第K个节点
		
首先,对于链表来说,我们不能像数组一样直接访问,所以我们想到要求倒数第K个节点首先要知道最后一个节点. 然后从最后一个节点往前数K个. 最后得到想要的值. 但是这是不对的,为什么呢?因为题目给出的是单 ...
 - python数据结构链表之单向链表
		
单向链表 单向链表也叫单链表,是链表中最简单的一种形式,它的每个节点包含两个域,一个信息域(元素域)和一个链接域.这个链接指向链表中的下一个节点,而最后一个节点的链接域则指向一个空值. 表元素域ele ...
 
随机推荐
- has leaked ServiceConnection com.baidu.location.LocationClient
			
02-06 05:01:52.806: E/ActivityThread(1120): Activity com.project.xxxActivity $1@45fc5af8 that was or ...
 - svg 文字
			
<text>标签 在svg中用使用<text>标签去定义一段文字.如 Example 1 在svg中写下 在平坦的路上曲折前行 Example 1 Dome <svg h ...
 - YII学习,初体验 ,对YII的一些理解.
			
先说点没用的: 不会选择,选择后不坚持,不断的选择.这是人生中的一个死循环,前两一直迷茫.觉得自己前进方向很不明朗.想去学的东西有很多.想学好YII,想学PYTHON 想学学hadoop什么的,又想研 ...
 - asp.net 获取当月的第一天和最后一天示例
			
DateTime now = DateTime.Now; DateTime d1 = ); DateTime d2 = d1.AddMonths().AddDays(-); d1是本月的第一天,d2本 ...
 - Android实现ListView或GridView首行/尾行距离屏幕边缘距离
			
直接上关键属性: 设置ListView或GridView的android:clipToPadding = true, 然后通过paddingTop和paddingBottom设置距离就好了.
 - linux下so动态库一些不为人知的秘密(上)
			
linux 下有动态库和静态库,动态库以.so为扩展名,静态库以.a为扩展名.二者都使用广泛.本文主要讲动态库方面知识. 基本上每一个linux 程序都至少会有一个动态库,查看某个程序使 ...
 - Easyui几种布局方式的使用
			
1.通过标记创建layout. 记得添加"easyui-layout"样式给div标记. <div id="cc" class="easyui ...
 - uva 10026 Shoemaker's Problem _贪心
			
题意:鞋匠现在有n个工作要做,每个工作要x天,没延迟一天需要付款y,鞋匠每天只能做一个工作,问使得鞋匠最少赔款的工作顺序. 思路:工作和工作之间排序,如果a.value*b.day>b.valu ...
 - python-django如何在sae中使用自带ImageField和FileField -django-上善若水小站
			
python-django如何在sae中使用自带ImageField和FileField -django-上善若水小站 python-django如何在sae中使用自带ImageField和FileF ...
 - #include <queue>
			
双端队列deque比向量vector更有优势 双端队列(deque) 连续存储的指向不同元素的指针所组成的数组<deque> 队列(queue) 先进先出的值的排列 <queue&g ...