Commit 4959c522 authored by Kirill Smelkov's avatar Kirill Smelkov

.

parent a727ee64
...@@ -349,6 +349,7 @@ func (t *Tree) Delete(k interface{} /*K*/) (ok bool) { ...@@ -349,6 +349,7 @@ func (t *Tree) Delete(k interface{} /*K*/) (ok bool) {
t.extract(dd, i) t.extract(dd, i)
if p != nil { if p != nil {
// NOTE underflow corrects hit D,Di, P,Pi, Kmin, Kmax as needed
t.underflow(p, dd, pi) t.underflow(p, dd, pi)
} else if t.c == 0 { } else if t.c == 0 {
t.Clear() t.Clear()
...@@ -421,7 +422,7 @@ func (t *Tree) Delete(k interface{} /*K*/) (ok bool) { ...@@ -421,7 +422,7 @@ func (t *Tree) Delete(k interface{} /*K*/) (ok bool) {
if x.c < kd { if x.c < kd {
if q != t.r { if q != t.r {
// NOTE underflow will correct hit Kmin, Kmax, P and Pi as needed // NOTE underflow corrects hit D,Di, P,Pi, Kmin, Kmax as needed
t.underflow(p, x, pi) t.underflow(p, x, pi)
} else if t.c == 0 { } else if t.c == 0 {
t.Clear() t.Clear()
...@@ -980,28 +981,25 @@ func (t *Tree) underflow(p *x, q *d, pi int) { ...@@ -980,28 +981,25 @@ func (t *Tree) underflow(p *x, q *d, pi int) {
l, r := p.siblings(pi) l, r := p.siblings(pi)
if l != nil && l.c+q.c >= 2*kd { if l != nil && l.c+q.c >= 2*kd {
//dbg("\tunderflow -> mv-from-l")
l.mvR(q, 1) l.mvR(q, 1)
p.x[pi-1].k = q.d[0].k p.x[pi-1].k = q.d[0].k
t.hitKmin.set(q.d[0].k) t.hitKmin.set(q.d[0].k)
t.hitPi = pi // XXX? (+ already pre-set this way ?) //t.hitPi = pi already pre-set this way
t.hitDi += 1 t.hitDi += 1
return return
} }
if r != nil && q.c+r.c >= 2*kd { if r != nil && q.c+r.c >= 2*kd {
//dbg("\tunderflow -> mv-from-r")
q.mvL(r, 1) q.mvL(r, 1)
p.x[pi].k = r.d[0].k p.x[pi].k = r.d[0].k
t.hitKmax.set(r.d[0].k) t.hitKmax.set(r.d[0].k)
t.hitPi = pi // XXX? (+ already pre-set this way ?) //t.hitPi = pi already pre-set this way
// hitDi stays the same // hitDi stays the same
r.d[r.c] = zde // GC r.d[r.c] = zde // GC
return return
} }
if l != nil { if l != nil {
//dbg("\tunderflow -> cat l <- q")
t.hitD = l t.hitD = l
t.hitDi += l.c t.hitDi += l.c
pi-- pi--
...@@ -1012,7 +1010,7 @@ func (t *Tree) underflow(p *x, q *d, pi int) { ...@@ -1012,7 +1010,7 @@ func (t *Tree) underflow(p *x, q *d, pi int) {
t.hitP = nil t.hitP = nil
t.hitPi = -1 t.hitPi = -1
} else { } else {
if pi > 0 { if pi > 0 { // k=-∞ @-1
t.hitKmin.set(p.x[pi-1].k) t.hitKmin.set(p.x[pi-1].k)
} }
t.hitPi = pi t.hitPi = pi
...@@ -1020,7 +1018,6 @@ func (t *Tree) underflow(p *x, q *d, pi int) { ...@@ -1020,7 +1018,6 @@ func (t *Tree) underflow(p *x, q *d, pi int) {
return return
} }
//dbg("\tunderflow -> cat q <- r")
t.cat(p, q, r, pi) t.cat(p, q, r, pi)
// hitD/hitDi stays unchanged // hitD/hitDi stays unchanged
t.hitKmax = t.hitPKmax t.hitKmax = t.hitPKmax
...@@ -1029,10 +1026,10 @@ func (t *Tree) underflow(p *x, q *d, pi int) { ...@@ -1029,10 +1026,10 @@ func (t *Tree) underflow(p *x, q *d, pi int) {
t.hitP = nil t.hitP = nil
t.hitPi = -1 t.hitPi = -1
} else { } else {
if pi < p.c { // means < ∞ if pi < p.c { // k=+∞ @p.c
t.hitKmax.set(p.x[pi].k) t.hitKmax.set(p.x[pi].k)
} }
t.hitPi = pi // XXX? (+ already pre-set this way ?) //t.hitPi = pi already pre-set this way
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment