riordinato alcuni package e creato una prima implementazione di set e mergetemplate

This commit is contained in:
2014-05-17 21:19:18 +02:00
parent 867a7c1a53
commit 4dab60c3fa
10 changed files with 254 additions and 9 deletions

View File

@@ -0,0 +1,30 @@
package utility.euler_tour.expressions;
import utility.euler_tour.EulerTour;
import position.Position;
import tree.binarytree.BinaryTree;
/**
* Created with MONSTER.
* User: xgiovio
* Date: 27/04/2014
* Time: 13:09
*/
public class EvaluateExpressionTour extends EulerTour<ExpressionTerm,Integer> {
public Integer execute(BinaryTree<ExpressionTerm> T) {
init(T);
return eulerTour(tree.root());
}
protected void visitRight(Position<ExpressionTerm> v, TourResult<Integer> r) {
ExpressionTerm term = v.element();
if (tree.isInternal(v)) {
ExpressionOperator op = (ExpressionOperator) term;
op.setOperands(r.left, r.right);
}
r.out = term.getValue();
}
}