From 9197d23dc6f5e1ca25d08a42d8c7c30b4c0a6e90 Mon Sep 17 00:00:00 2001 From: guoyongzhi Date: Wed, 6 Nov 2024 16:31:52 +0800 Subject: [PATCH] feat(LinkedList): delete the tail field of DoubleList type --- src/linkedlist.jl | 34 ++++++++++++++++++++++------------ src/qtrees.jl | 7 +++---- 2 files changed, 25 insertions(+), 16 deletions(-) diff --git a/src/linkedlist.jl b/src/linkedlist.jl index 0ef0b4a..777266a 100644 --- a/src/linkedlist.jl +++ b/src/linkedlist.jl @@ -1,5 +1,5 @@ module LinkedList -export DoubleList, ListNode, movetofirst!, IntMap, ishead, istail, seek_tail +export DoubleList, ListNode, movetofirst!, IntMap, ishead, istail, seek_head, seek_tail mutable struct ListNode{T} value::T prev::ListNode{T} @@ -19,16 +19,22 @@ end ListNode(value::T) where T = ListNode{T}(value) ishead(n::ListNode) = n.prev === n istail(n::ListNode) = n.next === n -function Base.iterate(l::ListNode, p=l) - istail(p) ? nothing : (p.value, p.next) +function Base.iterate(l::ListNode, p=l) # from this node to the end + istail(p) ? nothing : (p.value, p.next) end Base.IteratorSize(::Type{<:ListNode}) = Base.SizeUnknown() Base.eltype(::Type{ListNode{T}}) where T = T -function seek_tail(l::ListNode) - while !istail(l) - l = l.next +function seek_tail(n::ListNode) + while !istail(n) + n = n.next end - l + n +end +function seek_head(n::ListNode) + while !ishead(n) + n = n.prev + end + n end function Base.pop!(n::ListNode) n.prev.next = n.next @@ -38,23 +44,27 @@ end mutable struct DoubleList{T} head::ListNode{T} - tail::ListNode{T} + # tail::ListNode{T} end function DoubleList{T}() where T h = ListNode{T}() t = ListNode{T}() h.next = t t.prev = h - DoubleList(h, t) + DoubleList(h) end function DoubleList{T}(hv::T, tv::T) where T l = DoubleList{T}() l.head.value = hv - l.tail.value = tv + l.head.next.value = tv l end - -Base.isempty(l::DoubleList) = l.head.next === l.tail +function DoubleList{T}(hv::T) where T + l = DoubleList{T}() + l.head.value = hv + l +end +Base.isempty(l::DoubleList) = istail(l.head.next) function Base.pushfirst!(l::DoubleList, n::ListNode) n.next = l.head.next n.prev = l.head diff --git a/src/qtrees.jl b/src/qtrees.jl index aaaa83c..f8970f3 100644 --- a/src/qtrees.jl +++ b/src/qtrees.jl @@ -420,8 +420,7 @@ const SpacialQTreeNode = QTreeNode{LabelList} new_spacial_qtree_node(index::Index) = QTreeNode(LabelList(index)) new_spacial_qtree_node() = QTreeNode(LabelList()) function new_labellist(node::QTreeNode) - dl = DoubleList{Int}() - dl.tail.value = Int(pointer_from_objref(node)) + dl = DoubleList{Int}(Int(pointer_from_objref(node))) # @assert node == seek_treenode(dl.tail) node.value.list = dl end @@ -512,8 +511,8 @@ function Base.push!(t::LinkedSpacialQTree, inds, label::Int) end end function seek_treenode(listnode::ListNode{Int}) - tail = seek_tail(listnode) - unsafe_pointer_to_objref(Ptr{Any}(tail.value))::SpacialQTreeNode + head = seek_head(listnode) + unsafe_pointer_to_objref(Ptr{Any}(head.value))::SpacialQTreeNode end function Base.empty!(t::LinkedSpacialQTree, label) if haskey(t.map, label) && !isempty(t.map[label])