在这个问题中,我们得到了一个数组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