加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-13 20:15:39 所属栏目:百科 来源:网络整理
导读:【例2-4】已知单链表H,写一算法将其倒置,即实现如图2.14所示的操作,其中(a)为倒置前,(b)为倒置后。数据结构(C#语言版)2.3 单链表 57H 40 60 80 45 23 11 ∧ (a) 倒置前 H 11 23 45 80 60 40 ∧(b) 倒置后图2.14 单链表的倒置算法思路:由于单链表的存
【例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),但比同样长度的顺序表多花一倍的时间,因为顺序表只需要扫描一半的数据元素。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读