1. 问题描述

Implement a basic calculator to evaluate a simple expression string.

The expression string contains only non-negative integers, +, -, *, / operators and empty spaces . The integer division should truncate toward zero.

You may assume that the given expression is always valid.

Some examples:

"3+2*2" =
" 3/2 " =
" 3+5 / 2 " =

Note: Do not use the eval built-in library function.

Tags:String

Similar Problems:(H)Basic Calculator、(H)Expression Add Operators

Solution:

class Solution {
public:
int calculate(string s) { }
};

2. 解答思路

2.1 合法性判断

  • 空字符串
  • 在第一个数字字符('0'~'9')出现前(假设在位置i),则位置0到位置i的字符只能为空格‘ ’或一个正负号‘+’或‘-’号
  • 除数字、加、减、乘、除、空格字符外,其他字符均为非法字符,返回0。同时,需设置全局标志位,与计算结果为0进行区分
  • 有没有可能多个运算符字符相邻?e.g. "- +  /"、“*/-” etc. 不会,因为题目中说You may assume that the given expression is always valid.
  • 若有溢出如何处理

2.2 整数提取

  • 如何从相邻的多个空格与数字字符的串中,提取出整数

2.3 算法

  • 原则:两次循环,先算乘除、再算加减
  • 第1轮循环:若遇到乘除运算符,则将栈顶元素与提取的数字进行运算,删除栈顶元素,将结果入栈,依次类推...
  • 第2轮循环:将栈中元素依次取出进行加法运算

3. 代码

 #include <cctype>    //使用isdigit()、isspace()函数时需要
#include <stack> //使用STL stack时需要
using namespace std;
class Solution {
public:
int calculate(string s) {
long long num = ;
char ch_Oper = '+';//用于保存提取到的运算符
for (size_t i = ; i < s.size(); i++)//使用size()函数与使用length()函数的区别
{
if (isdigit(s[i])) //检查参数c是否为阿拉伯数字0到9
{
num = num * + s[i] - '';
} if (!isdigit(s[i]) && !isspace(s[i]) || i == s.size()-)//i == s.size()-1表示单独处理最后一个整数
{
switch (ch_Oper)
{
case '+':
break;
case '-':
num = -num;
break;
case '*':
num = numStack.top() * num;
numStack.pop();
break;
case '/':
num = numStack.top() / num;
numStack.pop();
break;
default:
break;
} numStack.push(num);
num = ;
ch_Oper = s[i];
}
} while (!numStack.empty())
{
num += numStack.top();
numStack.pop();
} return (int)num;
} private:
stack<long long> numStack;
};

4. 反思

本题代码中有处处理很是巧妙:

  • 若遇到负号运算符'-',则令num = -num,从而在第二次循环(while循环)中,只需进行加法运算。

小知识点:

  • isdigit()、isspace()的用法(需包含#include <ctype.h>(旧版),#include <cctype>(新版)头文件)
  • STL中stack容器的用法
  • string s, 如何判断其大小:s.size()、s.length();如何访问其中的某个字符:s[i]、s.at(i)
  • 如何使用堆栈实现算术运算,如何将减法转换为加法,如何处理乘除运算

227. Basic Calculator的更多相关文章

  1. leetcode 224. Basic Calculator 、227. Basic Calculator II

    这种题都要设置一个符号位的变量 224. Basic Calculator 设置数值和符号两个变量,遇到左括号将数值和符号加进栈中 class Solution { public: int calcu ...

  2. 【LeetCode】227. Basic Calculator II 解题报告(Python)

    [LeetCode]227. Basic Calculator II 解题报告(Python) 标签(空格分隔): LeetCode 作者: 负雪明烛 id: fuxuemingzhu 个人博客: h ...

  3. 224. Basic Calculator + 227. Basic Calculator II

    ▶ 两个四则表达式运算的题目,第 770 题 Basic Calculator IV 带符号计算不会做 Orz,第 772 题 Basic Calculator III 要收费 Orz. ▶ 自己的全 ...

  4. [LeetCode] 227. Basic Calculator II 基本计算器之二

    Implement a basic calculator to evaluate a simple expression string. The expression string contains ...

  5. LeetCode#227.Basic Calculator II

    题目 Implement a basic calculator to evaluate a simple expression string. The expression string contai ...

  6. Java for LeetCode 227 Basic Calculator II

    Implement a basic calculator to evaluate a simple expression string. The expression string contains ...

  7. 227. Basic Calculator II

    Implement a basic calculator to evaluate a simple expression string. The expression string contains ...

  8. (medium)LeetCode 227.Basic Calculator II

    Implement a basic calculator to evaluate a simple expression string. The expression string contains ...

  9. 【LeetCode】227. Basic Calculator

    Problem: Implement a basic calculator to evaluate a simple expression string. The expression string ...

随机推荐

  1. Windows 7安装教程(详细图解)

    早前向大家介绍了Windows XP的安装教程,今天思齐再来介绍一下Windows 7的安装教程,Windows 7在安装上相对以前的Windows操作系统都要简单一些,这一点对于尤其是非专业用户来说 ...

  2. CC++初学者编程教程(8) VS2013配置编程助手与QT

    1. 2. 配置编程助手 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. 24. 25. 26 ...

  3. 百度静态资源(JS)公共库

         例如: chosen http://apps.bdimg.com/libs/chosen/1.1.0/chosen.jquery.min.js   classlist http://apps ...

  4. R实战读书笔记四

    第三章 图形入门 本章概要 1 创建和保存图形 2 定义符号.线.颜色和坐标轴 3 文本标注 4 掌控图形维数 5 多幅图合在一起 本章所介绍内容概括例如以下. 一图胜千字,人们从视觉层更易获取和理解 ...

  5. 一些DevExpress控件概况!!!!主要DocumentManager.WindowsUIView.Tile

    WinForms Controls The links below provide comprehensive information on using DevExpress WinForms pro ...

  6. ASP.NET设置焦点到输入框

    Page.SetFocus(txtLoginName);

  7. Egret及Node.js的安装部署

    最近在学Html5游戏开发,我选择的是国内的一个游戏开发框架egret.因为涉及到node.js这个近年来新兴起来的技术.借此机会把这方面知识学习一下. node.js以及egret的操作类似于Lin ...

  8. MariaDB忘记root密码

    在MariaDB配置文件/etc/my.cnf  [mysqld]中加入skip-grant-tables一行: [Richard@localhost ~]$ sudo vi /etc/my.cnf[ ...

  9. XML CDATA(Mybatis mapper and XML)

    Tip:must be followed by either attribute specifications, ">" or "/>". 所有 X ...

  10. 解读机器学习基础概念:VC维的来龙去脉 | 数盟

    http://dataunion.org/14581.html