程序员面试宝典 C13数据结构基础 13.1 单链表

来源:互联网 发布:java官网下载旧版jdk 编辑:程序博客网 时间:2024/05/29 02:26

单链表

单链表的建立

单链表的测长

单链表的打印

单链表删除结点

单链表插入结点

单链表排序

我把问题看得太复杂了,用了太多的指针,而且排序的时候还交换了节点。

书上的例子就简单多了:
首先获取链表长度
采用顺序一样的冒泡排序
只使用一个指针,始终指向冒泡的两两比较的前一个节点
交换时直接交换两个结点的值(节点位置不变)

单链表逆置(原地逆置)

对于不带头节点的链表

使用3个指针p1,p2,p3
1. p1指向第一个节点,p1->p2->p3
2. p1与p2逆置p2->p1,p3记录未逆置的链表的第一个节点
3. p1 后移,p2后移,p3后移,转到 2,直至p2为NULL(即未逆置链表为空,p1指向尾结点)
4. 将原首节点指向NULL(改为新的尾结点),将head指向p1(改为新的首节点)

对于带头节点的链表

同时,但是注意开始和结尾的处理不同:
1. 开始p1指向第一个非头节点
2. 结束时head->next指向p1

删除单链表头结点

先后移,再释放内存

快慢指针

一次遍历求出不知道长度的单链表的中间节点

快慢指针的其他引用

判断单链表是否有环

输出单链表倒数第K个节点

阅读全文
0 0
原创粉丝点击