程序员面试宝典 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
- 程序员面试宝典 C13数据结构基础 13.1 单链表
- 程序员面试宝典之数据结构基础-----③单链表的插入
- 程序员面试宝典之数据结构基础----单链表的逆序打印
- 【程序员面试宝典】数据结构基础1:链表
- 程序员面试宝典之数据结构基础
- 【程序员面试宝典】数据结构基础三循环链表
- 程序员面试宝典之数据结构基础---⑤单链表逆序的递归与非递归实现
- 程序员面试宝典之数据结构基础----①单链表的建立、测长、打印(读后)
- 程序员面试宝典之数据结构基础----②单链表删除节点(读后)
- 程序员面试宝典之数据结构基础----④单链表排序(读后)
- 程序员面试宝典笔记5--数据结构
- 程序员面试宝典-2(数据结构与算法)
- 【程序员面试宝典】数据结构基础一单链表:创建|求长|插入|删除|排序|打印|逆置
- 【程序员面试宝典】数据结构基础二单链表循环链表的操作 建立|插入删除|打印|合并
- 程序员面试宝典之数据结构基础----⑥双链表的建立,插入和删除
- 程序员面试宝典之数据结构基础----循环链表(约瑟夫环问题)
- 程序员面试宝典之数据结构基础----队列的入队与出队
- 程序员面试宝典之数据结构基础----C++两个栈实现一个队列功能
- Mysql 地区经纬度 查询
- 关于关键词优化的那些必须知道的事?
- 自定义适配器
- Unity3d 技巧(10) -游戏上线 三星应用商店上传指南
- DataGrid Checkbox 数据设定、取值 如何通过post请求向后台提交[]数组
- 程序员面试宝典 C13数据结构基础 13.1 单链表
- 【PAT】【Advanced Level】1031. Hello World for U (20)
- Android开发 之 判断有无虚拟按键(导航栏)
- centos安装userspace-rcu
- 【博览网】面向对象高级编程(上)——第二周课程笔记
- solr的下载、两种运行方式
- java-API
- STL中的list容器的一点总结
- gvim 字体设置无效解决办法