我不确定如何使用 map 函数来评估我的树表达式。函数是这样的
int Tree::evaluate(std::map< std::string, int > ipMap){
我的老师给了我一个提示,以查看我的 postorder print 功能为例,但我不确定它如何应用于此。这里是:
void Tree::postOrderPrint(){
if(NodeType==TYPE_OPERATOR)
{
leftPtr->postOrderPrint();
rightPtr->postOrderPrint();
std::cout<< Op << " " ;
}
else
{
std::cout<< Op << " " ;
}
}
如果树已经构建,字符串从之前的函数中解析出来,并且这个函数真正要做的就是相当于下面的函数
int arithmetic_expression::evaluateTree(TreeNodePtr rootPtr)
{
if ((rootPtr->Op=="+") | (rootPtr->Op=="-")|(rootPtr->Op=="*")|(rootPtr->Op== "/"))
{
if (rootPtr->Op=="+")
{
return(evaluateTree(rootPtr->leftPtr)+ evaluateTree(rootPtr->rightPtr));
}
if (rootPtr->Op=="-")
{
return(evaluateTree(rootPtr->leftPtr)- evaluateTree(rootPtr->rightPtr));
}
if (rootPtr->Op=="*")
{
return(evaluateTree(rootPtr->leftPtr)* evaluateTree(rootPtr->rightPtr));
}
if (rootPtr->Op=="/")
{
return(evaluateTree(rootPtr->leftPtr)/ evaluateTree(rootPtr->rightPtr));
}
}
else
{
int Number;
std::istringstream(rootPtr->Op) >> Number;
return(Number);
}
}
这是调用该函数的内容:
int arithmetic_expression::evaluate_Expression(std::map< std::string, int > ipMap)
{
if (tree != NULL){
return(tree->evaluate(ipMap));
}
else
return(0);
}
这看起来有意义吗?
int Tree::evaluate(std::map< std::string, int > ipMap){
std::map<std::string, int >::iterator myIter;
myIter=ipMap.find(Op);
{
if (myIter=="+")
{
return(evaluate(leftPtr)+ evaluate(rightPtr))
}
if (myIter=="-")
{
return(evaluate(leftPtr)- evaluate(rightPtr));
}
if (myIter=="*")
{
return(evaluate(leftPtr)* evaluate(rightPtr));
}
if (myIter=="/")
{
return(evaluate(leftPtr)/ evaluate(rightPtr));
}
}
else{