[leetcode] Evaluate the value of reverse polish expression

/*
Evaluate the value of an arithmetic expression in Reverse Polish Notation.


Valid operators are +, -, *, /. Each operand may be an integer or another expression.


Some examples:
  ["2", "1", "+", "3", "*"] -> ((2 + 1) * 3) -> 9
  ["4", "13", "5", "/", "+"] -> (4 + (13 / 5)) -> 6

*/


简单题 使用栈模拟 逆波兰表达式的计算过程即可 

应注意使用streamstring 做多次类型转换时 要使用clear()方法 


部分代码写的比较繁琐 


/*
Evaluate the value of an arithmetic expression in Reverse Polish Notation.

Valid operators are +, -, *, /. Each operand may be an integer or another expression.

Some examples:
  ["2", "1", "+", "3", "*"] -> ((2 + 1) * 3) -> 9
  ["4", "13", "5", "/", "+"] -> (4 + (13 / 5)) -> 6
*/
#include <iostream>
#include <vector>
#include <stack>
#include <string>
#include <cstdio>
#include <sstream>
using namespace std;

class Solution{
public:
	int evalRPN(vector<string> &tokens)
	{
		stack<string> exp;
		int res;
		string op1,op2;
		int num1,num2;
		stringstream ss;
		for(int i = 0;i < tokens.size();i++)
		{
			switch (tokens[i].at(0))
			{
			case '+':
					{
					ss.clear();
					op2 = exp.top();
					ss << op2;
					ss >> num2;
					ss.clear();
					exp.pop();
					op1 = exp.top();
					ss << op1;
					ss >> num1;
					exp.pop();
					res = num1+num2;
					ss.clear();
					ss << res;
					ss >> op1;
					exp.push(op1);
					}
					break;
			case '-':
					{
					if(tokens[i].length() == 1 )
					{
						ss.clear();
						op2 = exp.top();
						ss << op2;
						ss >> num2;
						exp.pop();
						op1 = exp.top();
						ss.clear();
						ss << op1;
						ss >> num1;
						exp.pop();
						res = num1-num2;
						ss.clear();
						ss << res;
						ss >> op1;
						exp.push(op1);
					}
					else
						exp.push(tokens[i]);
					}
					break;
			case '*':
					{
					op2 = exp.top();
					ss.clear();
					ss << op2;
					ss >> num2;
					exp.pop();
					op1 = exp.top();
					ss.clear();
					ss << op1;
					ss >> num1;
					exp.pop();
					res = num1*num2;
					ss.clear();
					ss << res;
					ss >> op1;
					exp.push(op1);

					}
					break;
			case '/':
					{
					op2 = exp.top();
					ss.clear();
					ss << op2;
					ss >> num2;
					exp.pop();
					op1 = exp.top();
					ss.clear();
					ss << op1;
					ss >> num1;
					exp.pop();
					res = num1/num2;
					ss.clear();
					ss << res;
					ss >> op1;
					exp.push(op1);

					}
					break;
			default:
					exp.push(tokens[i]);
			}
		}
		op1 = exp.top();
		ss.clear();
		ss << op1;
		ss >> res;
		return res;
	}
};
int main()
{
	vector<string> s;
	s.push_back("3");
	s.push_back("-4");
	s.push_back("+");
	Solution a;
	cout << a.evalRPN(s)<< endl;
	return 0;
}


### 回答1: 使用reverse函数反转leetcode字符串的方法是:将字符串作为参数传入reverse函数,然后将反转后的字符串返回给调用者。例如:let reversedString = reverse("leetcode")。 ### 回答2: 要使用reverse函数反转leetcode这个字符串,可以使用以下步骤: 1. 将字符串"leetcode"转换为字符数组。可以使用字符串的toCharArray()方法,该方法会返回一个字符数组,其中每个元素是字符串的一个字符。 2. 定义两个指针,left和right,分别指向字符数组的首尾。 3. 循环交换left和right指向的字符,然后将left指针向右移动一位,将right指针向左移动一位,直到left指针大于等于right指针。 4. 将反转后的字符数组转换回字符串。可以使用字符数组的valueOf()方法,该方法会将字符数组转换为一个新的字符串。 以下是用Java代码实现上述步骤的示例: ```java public String reverseString(String s) { // 将字符串转换为字符数组 char[] chars = s.toCharArray(); // 定义两个指针 int left = 0; int right = chars.length - 1; // 循环交换字符 while (left < right) { char temp = chars[left]; chars[left] = chars[right]; chars[right] = temp; left++; right--; } // 将字符数组转换为字符串 return String.valueOf(chars); } ``` 通过调用reverseString("leetcode")函数,将会返回字符串"edocteel",即将"leetcode"反转的结果。 ### 回答3: 要使用reverse函数来反转字符串"leetcode",只需将字符串转换为一个列表,然后使用reverse函数来翻转该列表,最后将列表转回字符串即可。 首先,将字符串"leetcode"转换为一个字符列表,可以使用list函数来实现,即list("leetcode"),得到列表['l', 'e', 'e', 't', 'c', 'o', 'd', 'e']。 接下来,使用reverse函数来反转该列表,即reverse(['l', 'e', 'e', 't', 'c', 'o', 'd', 'e'])。 最后,将翻转后的列表转换回字符串,可以使用join函数将列表中的字符连接起来,即''.join(['e', 'd', 'o', 'c', 't', 'e', 'e', 'l'])。 所以,将字符列表['l', 'e', 'e', 't', 'c', 'o', 'd', 'e']翻转并转换为字符串的过程为:''.join(reverse(list("leetcode"))),得到的结果为"edocteel",即字符串"leetcode"反转后的结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值