用递归解决递归形式的问题:
data:image/s3,"s3://crabby-images/5079d/5079d4f7c1b6ffc6d035af2b0d96ad97470cb257" alt=""
表达式求值描述.png
表达式的定义是递归的:
data:image/s3,"s3://crabby-images/0270f/0270f3d52defe568e7f981fb4e9bbd0717eeb8d3" alt=""
子表达式.png
data:image/s3,"s3://crabby-images/ae887/ae887a33d8aa1f11bf379b61d214a4b9d5b8898d" alt=""
项.png
data:image/s3,"s3://crabby-images/97df6/97df6919fc76fe6ef98c81bff793e151162fd3a4" alt=""
因子.png
#include <iostream>
#include <cstring>
#include <cstdlib>
using namespace std;
//读入一个因子,并且返回其值
int factor_value();
//读入一个项,并且返回其值
int term_value();
//读入一个表达式,并且返回其值
int expression_value();
int main(int argc, char *argv[])
{
cout << "the result value is "<<expression_value()<< endl;
return 0;
}
int expression_value()
{
int result = term_value();//求一项的值
bool more = true;
while(more){
char op = cin.peek();//看第一个字符,不取走
if(op=='+'||op=='-'){
cin.get();//从输入中取走一个字符;
int value = term_value();
if(op=='+')result += value;
else result -= value;
}
else more = false;
}
return result;
}
int term_value()
{
int result = factor_value();//求一个因子的值
while(true){
char op = cin.peek();//看第一个字符,不取走
if(op=='*'||op=='/'){
cin.get();//从输入中取走一个字符;
int value = factor_value();
if(op=='*')result *= value;
else result /= value;
}
else break;
}
return result;
}
int factor_value()
{
int result = 0;
char c = cin.peek();
if(c == '('){
cin.get();
result = expression_value();
cin.get();
}
else {
while(isdigit(c)){
result = 10*result + c - '0';
cin.get();
c = cin.peek();
}
}
return result;
}
网友评论