📄 tree.java
字号:
/*
This file is part of the PolePosition database benchmark
http://www.polepos.org
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public
License along with this program; if not, write to the Free
Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
MA 02111-1307, USA. */
package org.polepos.circuits.sepang;
public class Tree {
private static long idGenerator;
public long id;
public Tree preceding;
public Tree subsequent;
public String name;
public int depth;
public Tree(){
}
public Tree(long id, String name, int depth){
this.id = id;
this.name = name;
this.depth = depth;
}
public static Tree createTree(int depth){
idGenerator = 0;
return createTree(depth, 0);
}
private static Tree createTree(int maxDepth, int currentDepth){
if(maxDepth <= 0){
return null;
}
Tree tree = new Tree();
if(currentDepth == 0){
tree.name = "root";
}else{
tree.name = "node at depth " + currentDepth;
}
tree.id = ++idGenerator;
tree.depth = currentDepth;
tree.preceding = createTree(maxDepth - 1, currentDepth + 1);
tree.subsequent = createTree(maxDepth - 1, currentDepth + 1);
return tree;
}
public static void traverse(Tree tree, TreeVisitor visitor){
if(tree == null){
return;
}
traverse(tree.preceding, visitor);
traverse(tree.subsequent, visitor);
visitor.visit(tree);
}
public int getDepth(){
return depth;
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -