链表和邻接表的总结
链表结构是之前我所不了解的一个结构,今天才认真的去琢磨
链表顾名思义,可以说就是一个链子一样左右的节点相互串在一起,会相互影响相互进行操作的,可以用数组l和数组r分别连接每个点的前端和后端,然后删除本节点只需要把左连右右连左即可
正如信息学奥赛进阶指南里面所叙述的链表支持在任意位置插入或删除,但只能按顺序依次访问其中的元素因此在下面这个题目中很适用,可以删除掉对后面操作有影响的节点
双链表:
例题1
题目链接如下
根据题意可简单表述成要找寻一个节点k前的所有值,使得a[k]-a[i]最小i<k
我们可以很轻易的想到用排序去找到一个最接近k的数,这样相减肯定会更小,但是不妥之处就是会将原来的顺序打乱导致无法辨别是否会在k以前
这个时候就有一种很巧妙的用链表的方法了。
可以用l和r分别去记录一个点左右两端的编号,可以先用一个数组p把每一个序号排序后在序列中的序号记录下来,然后用n从前往后进行操作,每次取出在排序中的标号id,再取出该该标号左右两端的标号即l[id]和r[id],分别作差看哪个更优秀,取那个点作答案,再删除当前这个点(用左连右右