From 37497d521d1122a9c5877b026b5e031837e683c8 Mon Sep 17 00:00:00 2001 From: 3e <474420502@qq.com> Date: Mon, 23 Mar 2020 00:48:59 +0800 Subject: [PATCH] finish TODO --- TODO | 3 +- tree/lsv/dtree.go | 1 + tree/lsv/itree.go | 78 +++++++++++++++++++++++++++++++++++++------- tree/lsv/lsv_test.go | 12 ++++--- 4 files changed, 78 insertions(+), 16 deletions(-) diff --git a/TODO b/TODO index 69fbaed..b1c673e 100644 --- a/TODO +++ b/TODO @@ -1 +1,2 @@ -旋转的size数值计算错误 \ No newline at end of file +1.旋转的size数值计算错误 +2.当左数比右数小的时候, 应该把split的数分配左边, 现在测试是一直保持拆分到右边 \ No newline at end of file diff --git a/tree/lsv/dtree.go b/tree/lsv/dtree.go index 35540a4..ec28f59 100644 --- a/tree/lsv/dtree.go +++ b/tree/lsv/dtree.go @@ -495,6 +495,7 @@ func (tree *DTree) putfeature(node *DNode) { if cur.family[2] == nil { cur.family[2] = node node.family[0] = cur + tree.feature = node break } } diff --git a/tree/lsv/itree.go b/tree/lsv/itree.go index d0825a4..10f188a 100644 --- a/tree/lsv/itree.go +++ b/tree/lsv/itree.go @@ -1,5 +1,9 @@ package lsv +import ( + "github.com/davecgh/go-spew/spew" +) + // INode 用于索引的节点 type INode struct { family [3]*INode @@ -24,7 +28,7 @@ type ITree struct { // New 生成一颗索引树 func New(Compare func(s1, s2 []rune) int) *ITree { - return &ITree{Compare: Compare, limit: 100} + return &ITree{Compare: Compare, limit: 10} } // Put return bool @@ -60,10 +64,15 @@ func (tree *ITree) Put(key, value []rune) (isInsert bool) { rspilt.family[0] = nil //清空右节点的父类, rsplit为根 lspilt.family[0] = nil // 上 + if cur.family[1].size < cur.family[2].size { + ilnode := NewINode() + ilnode.tree.root = lspilt + } + // 根树 新节点要插入到 右节点的最小值位置 即是 左~ irnode := NewINode() irnode.tree.root = rspilt - irnode.tree.feature = cur.tree.feature + irnode.tree.feature = cur.tree.feature // 右树最大值 icur := cur.family[2] @@ -87,16 +96,15 @@ func (tree *ITree) Put(key, value []rune) (isInsert bool) { } // 往上加+1 达到每个节点能统计size正确 // 调整3节点失衡的情况 - if cur.family[0] != nil && cur.family[0].size == 3 { - if cur.family[0].family[1] == nil { - tree.ilrrotate3(cur.family[0]) + if icur.family[0] != nil && icur.family[0].size == 3 { + if icur.family[0].family[1] == nil { + tree.ilrrotate3(icur.family[0]) } else { - tree.irrotate3(cur.family[0]) + tree.irrotate3(icur.family[0]) } } tempRoot := cur.tree.root - cur.tree.root = lspilt tempRoot.size = 1 @@ -132,11 +140,11 @@ func (tree *ITree) Put(key, value []rune) (isInsert bool) { } // 往上加+1 达到每个节点能统计size正确 // 调整3节点失衡的情况 - if cur.family[0] != nil && cur.family[0].size == 3 { - if cur.family[0].family[2] == nil { - tree.irlrotate3(cur.family[0]) + if icur.family[0] != nil && icur.family[0].size == 3 { + if icur.family[0].family[2] == nil { + tree.irlrotate3(icur.family[0]) } else { - tree.ilrotate3(cur.family[0]) + tree.ilrotate3(icur.family[0]) } } @@ -456,3 +464,51 @@ func (tree *ITree) ifixSizeWithRemove(cur *INode) { cur = cur.family[0] } } + +func ioutputfordebug(node *INode, prefix string, isTail bool, str *string) { + + if node.family[2] != nil { + newPrefix := prefix + if isTail { + newPrefix += "│ " + } else { + newPrefix += " " + } + ioutputfordebug(node.family[2], newPrefix, false, str) + } + *str += prefix + if isTail { + *str += "└── " + } else { + *str += "┌── " + } + + suffix := "(" + parentv := "" + if node.family[0] == nil { + parentv = "nil" + } else { + parentv = spew.Sprint(string(node.family[0].tree.root.key[0:3])) + } + suffix += parentv + "|" + spew.Sprint(node.size) + ")" + *str += spew.Sprint(string(node.tree.root.key[0:3])) + suffix + "\n" + + if node.family[1] != nil { + newPrefix := prefix + if isTail { + newPrefix += " " + } else { + newPrefix += "│ " + } + ioutputfordebug(node.family[1], newPrefix, true, str) + } +} + +func (tree *ITree) debugString() string { + str := "VBTree-Dup\n" + if tree.root == nil { + return str + "nil" + } + ioutputfordebug(tree.root, "", true, &str) + return str +} diff --git a/tree/lsv/lsv_test.go b/tree/lsv/lsv_test.go index cb9ed0e..de981ec 100644 --- a/tree/lsv/lsv_test.go +++ b/tree/lsv/lsv_test.go @@ -352,13 +352,17 @@ func loadTestData() [][]rune { func TestPut(t *testing.T) { tree := New(compareRunes) - + temp := "" for i := 0; i < 10000; i++ { - v := randomdata.FullDate() + ":" + strconv.Itoa(i) + randomdata.Street() + v := strconv.Itoa(i) + ":" + randomdata.FullDate() + randomdata.Street() + // v := strconv.Itoa(i) tree.Put([]rune(v), []rune(v)) - if tree.root.size == 2 { - t.Error("213") + + if temp != tree.debugString() { + t.Error(tree.debugString()) + temp = tree.debugString() } + } t.Error("123") }