未完待续 还差个删除,删除貌似比较难
package main
import "fmt"
type node struct {
key int
value int
left *node
right *node
color int
}
type RBST struct {
head *node
n int
}
func (this *RBST)put(key,value int){
if this.head == nil{
this.head = &node{key:key,value:value,color:1}
return
}
this.head = this.putValue(this.head,key,value)
return
}
func (this *RBST)rotateLeft(node *node)*node{
tmp := node.right
node.right = node.right.left
tmp.left = node
tmp.color = 1
node.color = 2
return tmp
}
func (this *RBST)rotateRight(node *node)*node{
tmp := node.left
node.left = node.left.right
tmp.right = node
tmp.color = 1
node.color = 2
return tmp
}
func (this *RBST)flipColor(node *node)*node{
node.left.color = 1
node.right.color = 1
node.color = 2
return node
}
func (this *RBST)get(key int)int{
return this.getValue(this.head,key)
}
func (this *RBST)getValue(node *node,key int)int{
if node == nil{
return 0
}
if key > node.key{
return this.getValue(node.right,key)
}else if key < node.key{
return this.getValue(node.left,key)
}
return node.value
}
func (this *RBST)putValue(Node *node,key int,value int)*node{
if Node == nil{
return &(node{key:key,value:value,color:2})
}
if key > Node.key{
Node.right = this.putValue(Node.right,key,value)
}else if key < Node.key{
Node.left = this.putValue(Node.left,key,value)
}else{
Node.value = value
return Node
}
//如果有右红链接 则左转
if Node.right != nil && Node.right.color == 2 && ( (Node.left != nil && Node.left.color == 1) || Node.left == nil){
Node = this.rotateLeft(Node)
}
//如果有左子子红链接 则右转
if Node.left != nil && Node.left.left != nil && Node.left.color == 2 && Node.left.left.color == 2{
Node = this.rotateRight(Node)
}
//如果左子红链接 且右子红链接 则 flipcolor
if Node.right != nil && Node.left != nil && Node.right.color == 2 && Node.left.color == 2{
Node = this.flipColor(Node)
}
return Node
}
func main(){
var redBlack RBST
redBlack.put(1,1)
redBlack.put(2,2)
redBlack.put(3,3)
redBlack.put(4,4)
redBlack.put(5,5)
redBlack.put(6,6)
redBlack.put(7,7)
redBlack.put(8,8)
redBlack.put(9,9)
fmt.Println(redBlack.get(9))
}
网友评论