当前位置: 首页 > news >正文

浅谈链表的优化技巧

浅谈链表的优化技巧

麻烦写法:

正常写链表,都是一个头元素 head 一个尾元素 tail 来记录链表的虚拟头和虚拟尾或真实头和真实尾。

但是显然在插入操作和删除操作的时候,这种写法就会显得很麻烦,要特判一大堆情况:

  • 插入的元素在链表头:更新 head 且只要更新两条关系链。
  • 在中间:最正常,没话说,需更新四条关系链:pre → \rightarrow cur & cur → \rightarrow pre & cur → \rightarrow nxt & nxt → \rightarrow pre。
  • 在末尾:更新 tail 且只要更新两条。

给个代码:

	void Insert(int i,char ch){++tot;node[tot].ch=ch;if(!h)h=t=tot;else{if(!i){node[tot].nxt=h,node[h].pre=tot;h=tot;}else{int x=Find(i),y=node[x].nxt;node[tot].pre=x;node[tot].nxt=y;if(!y)t=tot;elsenode[y].pre=tot;node[x].nxt=tot;}}++m;return;}void del(int i){if(m==1)h=t=0;else{if(i==1){h=node[h].nxt;node[h].pre=0;}else{if(i==m){t=node[t].pre;node[t].nxt=0;}else{int x=Find(i);int l=node[x].pre,r=node[x].nxt;node[r].pre=l;node[l].nxt=r;}}}--m;return;}

看着就很头疼啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊。。。

怎么说。。细节太多了,不好搞。码量大,还容易炸。

优化方法:

为链表添加虚拟的头尾元素。使得真正的链表只在虚拟头之后、虚拟尾之前。

  • 初始化时添加,所以链表至少有两个元素
  • 操作时不会涉及到虚拟元素,所以可以避免操作链表头尾

怎么样,看着就挺 nice 的。

操作事项:

  • 虚拟头的后面就是真正头
  • 虚拟尾的后面就是真正尾
  • 虚拟头的靠后元素为虚拟尾时,实际链表为空链表

别急——此时还能优化!

有种链表叫做环形链表,即 node[tail].nxt=headnode[head].pre=tail

那么我们就不用用两个虚拟元素,用一个虚拟元素将链表连成环形

  • 只需要一个虚拟元素,环形链表没有链表头和链表尾
  • 操作时不会涉及到虚拟元素,所以链表不可能是空链表
  • 虚拟元素的靠后元素就是真实头
  • 虚拟元素的考前元素就是实际尾
  • 虚拟元素的靠后元素为自己时,实际链表为空

好处呢?

通常用下标为 0 0 0 的元素作为虚拟元素(造福了数组模拟链表党)

  • 空指针也用 0 0 0 表示
  • 可以访问下标为 0 0 0 的元素,但是不能访问空指针

这时候懒得打代码怎么办?

Copy 一下老师的代码

void Insert(int i, char c) {      // 第 i 个字符后插入 ce[++n] = {c};                   // 新插入的元素int x = Find(i), y = e[x].nxt;  // 找到插入位置 xe[n].prv = x, e[n].nxt = y;     // 新元素 n 与两边建立联系e[y].prv = e[x].nxt = n;++m;
}void Delete(int i) {int x = Find(i), l = e[x].prv, r = e[x].nxt;e[r].prv = l, e[l].nxt = r;m--;
}

是不是瞬间清洗许多?

撒花~~

相关文章:

  • 如何修复卡在恢复模式下的 iPhone:简短指南
  • Linux(用户管用户与用户组管理理)
  • 在 Windows 环境下测试 8100 端口是否开放和正在监听
  • 【Java面试笔记:进阶】26.如何监控和诊断JVM堆内和堆外内存使用?
  • Redis 学习笔记 | 常用命令
  • 香港科技大学广州|生命科学与生物医学工程学域博士项目招生宣讲会—南京大学专场!!!(暨全额奖学金政策)
  • 测试—概念篇
  • BT131-ASEMI无人机专用功率器件BT131
  • 如何快速在idea中希望Spark程序
  • JAVA基础:Collections 工具类实战指南-从排序到线程安全
  • Vtable
  • 如何用postman进行批量操作
  • 根据用户出生日期计算年龄
  • 从暴力到优化:解决「分数严格小于k的子数组数目」问题
  • 代码随想录算法训练营第六十一天 | floyd算法
  • JAVA JVM面试题(二)
  • 【angular19】入门基础教程(二):组件的创建与使用
  • DeepSeek智能时空数据分析(六):大模型NL2SQL绘制城市之间连线
  • J-Link RTT打印输出调试信息
  • 普推知产:商标驳回复审下初步审定公告了!
  • 何立峰出席驻沪中央金融机构支持上海建设国际金融中心座谈会并讲话
  • 绿地控股:今年一季度营业收入356亿元,中高层管理人员带头降薪
  • 从咖啡节到话剧、演唱会,上海虹口“文旅商体展”联动促消费
  • 解放日报头版聚焦“人民城市”:共建共享展新卷
  • 大家聊中国式现代化|陶希东:打造高水平安全韧性城市,给群众看得见的安全感
  • 美媒:受关税政策影响,美国电商平台近千种商品平均涨价29%