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

单链表

单链表的建立

单链表的测长

单链表的打印

单链表删除结点

单链表插入结点

单链表排序

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

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

单链表逆置(原地逆置)

对于不带头节点的链表

使用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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值