在这个问题中,我们得到了一个数组arr [],该数组arr []由表示一个表达式的n个字符值组成。我们的任务是使用数字+和–评估数组表达式。
该表达式仅由数字,'+'字符和'-'字符组成。
输入: arr = {“ 5”,“ +”,“ 2”,“-8”,“ +”,“ 9”,}
输出: 8
解释:
表达式是5 + 2-8 + 9 = 8
通过执行每个操作然后返回值来找到问题的解决方案。每个数字都需要转换为其等效的整数值。
#include <bits/stdc++.h>
using namespace std;
int solveExp(string arr[], int n) {
if (n == 0)
return 0;
int value, result;
result = stoi(arr[0]);
for (int i = 2; i < n; i += 2)
{
int value = stoi(arr[i]);
if (arr[i - 1 ] == "+")
result += value;
else
result -= value;
}
return result;
}
int main() {
string arr[] = { "5", "-", "3", "+", "8", "-", "1" };
int n = sizeof(arr) / sizeof(arr[0]);
cout<<"方程的解是 "<<solveExp(arr, n);
return 0;
}方程的解是 9