mirror of https://github.com/01-edu/public.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
88 lines
2.5 KiB
88 lines
2.5 KiB
5 years ago
|
package main
|
||
5 years ago
|
|
||
|
import (
|
||
|
"github.com/01-edu/z01"
|
||
|
|
||
5 years ago
|
"fmt"
|
||
|
|
||
5 years ago
|
solutions "./solutions"
|
||
|
student "./student"
|
||
|
)
|
||
|
|
||
5 years ago
|
func errorMessage_search(fn interface{}, root, a *solutions.TreeNode, b *student.TreeNode,
|
||
5 years ago
|
seaVal string) {
|
||
5 years ago
|
z01.Fatalf("%s(\n%s\n, %s) == %s instead of %s\n",
|
||
|
"BTreeSearchItem",
|
||
5 years ago
|
solutions.FormatTree(root),
|
||
|
seaVal,
|
||
|
b.Data,
|
||
|
a.Data,
|
||
|
)
|
||
|
}
|
||
|
|
||
5 years ago
|
func CompareNode_search(fn interface{}, arg1, a *solutions.TreeNode, b *student.TreeNode,
|
||
5 years ago
|
seaVal string) {
|
||
|
if a == nil && b == nil {
|
||
|
return
|
||
|
}
|
||
|
|
||
|
if (a == nil && b != nil) || (b == nil && a != nil) {
|
||
5 years ago
|
z01.Fatalf("Expected %v instead of %v\n", a, b)
|
||
5 years ago
|
return
|
||
|
}
|
||
|
|
||
|
if a.Data != b.Data {
|
||
5 years ago
|
errorMessage_search(fn, arg1, a, b, seaVal)
|
||
5 years ago
|
}
|
||
|
|
||
|
if a.Parent != nil && b.Parent != nil {
|
||
|
if a.Parent.Data != b.Parent.Data {
|
||
5 years ago
|
errorMessage_search(fn, arg1, a, b, seaVal)
|
||
|
z01.Fatalf("Expected parent value %v instead of %v\n", a.Parent.Data, b.Parent.Data)
|
||
5 years ago
|
fmt.Println("Parent.Data", a.Parent.Data, b.Parent.Data)
|
||
|
}
|
||
|
} else if (a.Parent == nil && b.Parent != nil) || (a.Parent != nil && b.Parent == nil) {
|
||
5 years ago
|
z01.Fatalf("Expected parent value %v instead of %v\n", a.Parent, b.Parent)
|
||
5 years ago
|
}
|
||
|
|
||
|
if a.Right != nil && b.Right != nil {
|
||
|
if a.Right.Data != b.Right.Data {
|
||
5 years ago
|
errorMessage_search(fn, arg1, a, b, seaVal)
|
||
|
z01.Fatalf("Expected right child value %v instead of %v\n", a.Right.Data, b.Right.Data)
|
||
5 years ago
|
fmt.Println("Right.Data", a.Right.Data, b.Right.Data)
|
||
|
}
|
||
|
} else if (a.Right == nil && b.Right != nil) || (a.Right != nil && b.Right == nil) {
|
||
5 years ago
|
z01.Fatalf("Expected right child value %v instead of %v\n", a.Right, b.Right)
|
||
5 years ago
|
}
|
||
|
|
||
|
if a.Left != nil && b.Left != nil {
|
||
|
if a.Left.Data != b.Left.Data {
|
||
5 years ago
|
errorMessage_search(fn, arg1, a, b, seaVal)
|
||
|
z01.Fatalf("Expected left child value %v instead of %v\n", a.Left, b.Left)
|
||
5 years ago
|
fmt.Println("Left.Data", a.Left.Data, b.Left.Data)
|
||
|
}
|
||
|
} else if (a.Left == nil && b.Left != nil) || (a.Left != nil && b.Left == nil) {
|
||
5 years ago
|
z01.Fatalf("Expected left child value %v instead of %v\n", a, b)
|
||
5 years ago
|
}
|
||
|
}
|
||
|
|
||
5 years ago
|
func main() {
|
||
5 years ago
|
root := &solutions.TreeNode{Data: "04"}
|
||
|
rootS := &student.TreeNode{Data: "04"}
|
||
|
|
||
|
ins := []string{"01", "07", "05", "12", "02", "03", "10"}
|
||
|
|
||
|
for _, v := range ins {
|
||
|
root = solutions.BTreeInsertData(root, v)
|
||
|
rootS = student.BTreeInsertData(rootS, v)
|
||
|
}
|
||
|
fn := interface{}(solutions.BTreeSearchItem)
|
||
|
|
||
|
ins = append(ins, "322")
|
||
|
for _, v := range ins {
|
||
|
selectedSol := solutions.BTreeSearchItem(root, v)
|
||
|
selectedStu := student.BTreeSearchItem(rootS, v)
|
||
5 years ago
|
CompareNode_search(fn, root, selectedSol, selectedStu, v)
|
||
5 years ago
|
}
|
||
|
}
|