У меня есть этот код в JS, который преобразует какой-то материализованный путь в древовидную структуру:
var input = [[1201], [1201,1202,1203,1204], [1201,1202,1203], [1201,1202], [1201,1205]];
var output = [];
for (var i = 0; i < input.length; i++) {
var chain = input[i];
var currentNode = output;
for (var j = 0; j < chain.length; j++) {
var wantedNode = chain[j];
var lastNode = currentNode;
for (var k = 0; k < currentNode.length; k++) {
if (currentNode[k].name == wantedNode) {
currentNode = currentNode[k].children;
break;
}
}
if (lastNode == currentNode) {
var newNode = currentNode[k] = {name: wantedNode, children: []};
currentNode = newNode.children;
}
}
}
Работает нормально и дает ожидаемый результат:
[
{
"name": 1201,
"children": [
{
"name": 1202,
"children": [
{
"name": 1203,
"children": [
{
"name": 1204,
"children": []
}
]
}
]
},
{
"name": 1205,
"children": []
}
]
}
]
Но у меня есть некоторые проблемы с портированием его на Go. Ближайшее решение на данный момент:
type tree struct {
ID int `json:"name"`
Children []*tree `json:"children"`
}
func (t *tree) get(id int) *tree {
for _, c := range t.Children {
if c.ID == id {
return c
}
}
return nil
}
func (t *tree) hasChild(id int) bool {
for _, c := range t.Children {
if c.ID == id {
return true
}
}
return false
}
root := tree{}
var tmpRoot *tree
for _, chain := range input {
if len(chain) == 1 {
root.ID = chain[0]
root.Children = make([]*tree, 0)
tmpRoot = &root
} else {
// id := chain[len(chain)-1]
parentID := chain[len(chain)-2]
for i, id := range chain {
if len(chain) < 2 || i == 0 {
continue
}
if tmpRoot.ID == parentID {
tmpRoot.Children = append(tmpRoot.Children, &tree{
ID: id,
Children: make([]*tree, 0),
})
} else {
if !tmpRoot.hasChild(id) {
tmpRoot = &tree{
ID: id,
Children: make([]*tree, 0),
}
tmpRoot.Children = append(root.Children, tmpRoot)
}
tmpRoot = tmpRoot.get(id)
}
}
}
}
Но все же некоторые значения отсутствуют на разных входах, скажем
[[1201], [1201, 1205], [1201, 1207], [1201, 1202], [1201, 1202, 1206], [1201, 1202, 1203], [1201, 1202, 1203, 1204], [1201, 1202, 1203, 1208]]
дает мне
{"name":1201,"children":[{"name":1205,"children":[]},{"name":1207,"children":[]},{"name":1202,"children":[{"name":1206,"children":[]},{"name":1202,"children":[]},{"name":1203,"children":[]}]}]}
Любая помощь приветствуется.
Игровая площадка Go: https://play.golang.org/p/XIHbaDHkp0m