单链表-----单链表的倒置
发布时间: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),但比同样长度的顺序表多花一倍的时间,因为顺序表只需要扫描一半的数据元素。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- oracle – 为什么我不应该创建所有PL / SQL-only VARCHAR2
- 在C中的元编程中,保护从非const-volatile类型到const-volat
- 杭电OJ--1003题C++实现
- 解决“System.Data.OracleClient需要Oracle客户端软件8.1.7
- Oracle 18c 数据库发布了(计划在2018年提供下载-传统DBA应
- c# – 在WinForm上运行数字时钟
- oracle 11g 后台进程备记--方便自己以后查看
- ruby-on-rails – 在Rails 4应用程序中添加新页面
- c# – 多个等待操作或只有一个
- 返回JSONP的Restful api的节点HTTP请求