单链表-----单链表的倒置

前端之家收集整理的这篇文章主要介绍了单链表-----单链表的倒置前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
【例2-4】已知单链表H,写一算法将其倒置,即实现如图2.14所示的操作,其中(a)为倒置前,(b)为倒置后。
数据结构(C#语言版)
2.3 单链表 57
H 40 60 80 45 23 11 ∧ (a) 倒置前 H 11 23 45 80 60 40 ∧
(b) 倒置后
图2.14 单链表的倒置
算法思路:由于单链表的存储空间不是连续的,所以,它的倒置不能像顺序表那样,把第i个结点与第n-i个结点交换(i的取值范围是1到n/2,n为单链表的长度)。其解决办法是依次取单链表中的每个结点插入到新链表中去。并且,为了节省内存资源,把原链表的头结点作为新链表的头结点。
存储整数的单链表的倒置的算法实现如下:
public void ReversLinkList(LinkList<int> H)
{
Node<int> p = H.Next;
Node<int> q = new Node<int>();
H.Next = null;
while (p != null)
{
q = p;			//将链表头指针赋值给新链表
p = p.Next;//旧链表指针向后移
q.Next = H.Next;//第一次为清空新链表的NEXT指针,之后为将当前新链表的头指针赋值给新加入的项的NXET指针
H.Next = q;//将新链表刚加入的项赋值给H.NEXT指针
}
}
该算法要对链表中的结点顺序扫描一遍才完成了倒置,所以时间复杂度为O(n),但比同样长度的顺序表多花一倍的时间,因为顺序表只需要扫描一半的数据元素。
原文链接:https://www.f2er.com/javaschema/287057.html

猜你在找的设计模式相关文章