Chinaunix首页 | 论坛 | 博客
  • 博客访问: 41143
  • 博文数量: 37
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 372
  • 用 户 组: 普通用户
  • 注册时间: 2013-10-12 23:27
文章分类

全部博文(37)

文章存档

2014年(5)

2013年(32)

我的朋友

分类: C/C++

2013-11-28 09:42:18

用栈。遇到数字压栈。遇到运算符则弹出前两个操作数计算结果并压栈。最后字符串矢量都处理完了就得到结果。




点击(此处)折叠或打开

  1. class Solution {
  2. public:
  3.     int evalRPN(vector<string> &tokens) {
  4.         // IMPORTANT: Please reset any member data you declared, as
  5.         // the same Solution instance will be reused for each test case.
  6.         stack<int> st;
  7.         for(int i=0;i<tokens.size();i++)
  8.         {
  9.             if("+"==tokens[i]||"-"==tokens[i]||"*"==tokens[i]||"/"==tokens[i])
  10.             {
  11.                 int n1=st.top(); st.pop();
  12.                 int n2=st.top(); st.pop();
  13.                 if("+"==tokens[i]) st.push(n1+n2);
  14.                 if("-"==tokens[i]) st.push(n2-n1);
  15.                 if("*"==tokens[i]) st.push(n1*n2);
  16.                 if("/"==tokens[i]) st.push(n2/n1);
  17.                 continue;
  18.             }
  19.             int num=0;
  20.             int minus=false;
  21.             for(int j=0;j<tokens[i].length();j++)
  22.             {
  23.                 if('-'==tokens[i][j]) {minus=true; continue;}
  24.                 num=10*num+tokens[i][j]-'0';
  25.             }
  26.             if(minus) num=0-num;
  27.             st.push(num);
  28.         }
  29.         return st.top();
  30.     }
  31. };

阅读(581) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~