• 新增:

    • 计算类(拥有计算功能)

      • 采用符号优先级计算方法

      • 对符号不匹配的如 -2 ,自动补为 0-2

    • 计算内核信息

      • 输入 -a 可以显示等式与结果

      • 输入 -p 可以显示计算逐步过程

        • 传入 -a 参数 且 传入 -p 参数

        • 传入 -a 参数 且 不传入 -p 参数


  • 规定并非万无一失,但暂未发现有悖原意的bug。

  • 如有发现bug,但求一知,万分感谢。


//
// main.cpp
// Calculator
//
// Created by admin on 16/2/25.
// Copyright © 2016年 YooRarely. All rights reserved.
// #include <iostream>
#include <queue>
#include <stack>
#include <string>
#include <cmath>
#include <sstream> using namespace std; class Scan{ private:
bool err; // 输入是否出错 public:
// 字符是否为运算符
bool isOper(char c){ if ( c == '+' || c == '-' || c == '*' || c == '/' ) return true;
return false;
}
// 字符是否为数字
bool isCount(char c){ if (c>='0' && c<='9') return true;
return false;
} queue <string> ToStringQueue(string input){
err=false;
queue <string > a;
int sum_kuohao = 0; // 当输入未出错时遍历输入字符串
for (int i = 0; i < input.size() && ! err; i ++){ string s; // 如果为 运算符 或 括号
if ( isOper( input[i] ) || input[i] == '(' || input[i] == ')' ) { s = input[i]; if (!a.empty()){ string k=a.back(); if (input[i] == '(' && ( isCount( k[0] ) || k[0] == ')' ) ) err = true;
if ( isOper( k[0] ) && input[i] != '(' && input[i] != '-' ) err = true; } if (input[i] == '(') sum_kuohao ++;
if (input[i] == ')') sum_kuohao --;
if ( sum_kuohao < 0 ) err = true; }// 否则 如果为数字
else if ( isCount( input[i] ) ){ bool dian=false; while ( ! err && i < input.size() ){
if ( isCount( input[i] ) || input[i] == '.') s=s+input[i];
if ( input[i] == '.' ) { if ( dian ) err = true;
dian = true; } if ( isOper( input[i+1] ) || input[i+1] == '(' || input[i+1] == ')') break;
i++;
} if (dian && s[ s.size() - 1 ] == '.') err = true;
if ( s.size() > 10 ) err = true; }
// 入队
a.push(s);
s="";
}
if ( sum_kuohao ) err = true; if ( ! err && ! a.empty() ){ string k = a.front();
if ( isOper( k[0] ) && k[0] != '-' ) err = true;
k = a.back();
if ( isOper( k[0] ) ) err = true; }
if ( err ) { while ( ! a.empty() ) a.pop();
a.push("Error Input !"); }
return a;
}
}; class Print{
public:
void PrintStringQueue(queue<string> a){ while ( ! a.empty() ) { cout << a.front() << endl;
a.pop();
}
}
}; class Calculate{
private:
bool print;
int tried (stack <char> &oper,stack <int> &important,stack <double> &count, int k){ while ( ! important.empty() && k <= important.top()){ double amazing = count.top();
count.pop(); switch (oper.top()) {
case '+':
if (print) cout<<count.top()<<"+"<<amazing;
count.top() += amazing;
if (print) cout<<"="<<count.top()<<endl;
break;
case '-':
if (print) cout<<count.top()<<"-"<<amazing;
count.top() -= amazing;
if (print) cout<<"="<<count.top()<<endl;
break;
case '*':
if (print) cout<<count.top()<<"*"<<amazing;
count.top() *= amazing;
if (print) cout<<"="<<count.top()<<endl;
break;
case '/':
if (amazing == 0) { return -1;}
if (print) cout<<count.top()<<"/"<<amazing;
count.top() /= amazing;
if (print) cout<<"="<<count.top()<<endl;
break;
} oper.pop();
important.pop();
}
return 0;
} public:
// 字符是否为运算符
bool isOper(char c){
if ( c == '+' || c == '-' || c == '*' || c == '/' ) return true;
return false;
}
// 字符是否为数字
bool isCount(char c){
if (c>='0' && c<='9') return true;
return false;
} double getAns(queue<string> a,bool p){ stack <char> oper;
stack <int> important;
stack <double> count;
int k=0;
print=p; while ( ! a.empty() ){ if (a.front()[0] == '(') k += 2;
if (a.front()[0] == ')') k -= 2; if (isOper( a.front()[0] )){ if ( oper.size() == count.size() ){ count.push(0);
important.push(10000); }
else if ( a.front()[0] == '*' || a.front()[0] == '/'){ if ( tried(oper, important, count, k+1) == -1 ) return 0.000000;
important.push(k+1); }
else{ if ( tried(oper, important, count, k) == -1 ) return 0.000000;
important.push(k); }
oper.push( a.front()[0] );
}
if (isCount( a.front()[0] )){ count.push( atof( a.front().c_str() ) ); } a.pop();
} if ( ! oper.empty() )
if ( tried(oper, important, count, -1) == -1 ) return 0.000000;
return count.top();
} }; int main(int argc, const char * argv[]) {
string input;
bool p,a;
double ans;
int i;
Scan scan;
Print print;
Calculate Calculate; p=false;
a=false;
i=1; // getline(cin,input); if (argc<2) return 0; input=argv[i]; while (1){ if (input=="-a") {
input=argv[++i];
a=true;
continue;
} if (input=="-p"){
input=argv[++i];
p=true;
continue;
} break;
} // print.PrintStringQueue( scan.ToStringQueue(input) ); ans=Calculate.getAns( scan.ToStringQueue(input) , p); if (a) cout<<input<<"=";
cout<<ans<<endl;
return 0;
}

Calculator 2的更多相关文章

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

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

  2. [LeetCode] Basic Calculator 基本计算器

    Implement a basic calculator to evaluate a simple expression string. The expression string may conta ...

  3. Basic Calculator II

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

  4. Windows Universal 应用 – Tip Calculator

    声明 以下内容取材于 Bob Tabor 的课程<Windows Phone 8.1 Development for Absolute Beginners>,链接地址为:http://ww ...

  5. Calculator(1.5)

    Calculator(1.5) Github链接 ps.负数的处理未完成 解题过程中遇到的困难和解决 <stack>的使用: 认真研究了栈,基本上掌握了用法,与<queue>的 ...

  6. Calculator(1.0)

    Calculator(1.0) Github链接 解题过程中遇到的困难 对于c++中类和对象的使用不够明确,看了c++的视频教程学会了用类和对象来写程序. 不会使用<queue>,在网上查 ...

  7. 数据结构与算法(1)支线任务2——Basic Calculator

    题目:https://leetcode.com/problems/basic-calculator/ Implement a basic calculator to evaluate a simple ...

  8. calculator

    #include <stdio.h> #include <stdlib.h> typedef enum { FALSE = , TRUE }BOOL; void calcula ...

  9. Basic Calculator

    本博客介绍leetcode上的一道不难,但是比较经典的算法题. 题目如下: Implement a basic calculator to evaluate a simple expression s ...

  10. Matrix Calculator

    表达式分析+矩阵+计算器+寄存器=矩阵计算器 怎么想起来搞这个呢.. //刚看龙书兴致勃勃要搞表达式分析 这个寄存器比较简陋,26字母+4缓存,//字母不分大小写 当然,不只能算矩阵,还能算数= = ...

随机推荐

  1. HTML a的连接

    QQ电脑端 <a target="_blank" href="http://wpa.qq.com/msgrd?v=3&uin=XXXXXX&site ...

  2. TinyMCE插件:FileManager [4.x-6.x] 配置及BUG处理

    FileManager最新版已升级到9.x,9.x新增了对文件的批量处理,但仍然有部分同学在继续使用6.x,这里大叔整理了一份自己在配置6.x时,遇到的问题和解决方案. 安装 下载安装包解压后,在根目 ...

  3. Kibana6.3.1安装

    Kibana安装 Kibana官方下载地址: https://www.elastic.co/cn/downloads/kibana 也可以直接使用以下命令下载(文章下载目录一概为/home/tools ...

  4. PHP基础2--基本语法

    主要: 标记符,注释 变量 常量 数据类型 运算符 流程控制 标记符,注释 4种标记符号: 1.  默认形式:  <?php    php语句      ?> 如果<?php ... ...

  5. PHP 通过命令异步执行PHP程序

    通过PHP执行系统命令调用PHP执行程序,让进程挂起到后台执行,不影响用户页面交互. 控制器调用命令,不用等待,后台创建一个进程执行程序. system(“nohup php command.php ...

  6. 在我的职业生涯中,没有一种技能比 SQL 更有用!

    作者 | Craig Kerstiens 译者 | 阿拉丁 创业公司 CitusData(CitusData 是一家将 PostgreSQL 商业化的初创企业,也是 PostgreSQL 社区领导者, ...

  7. Python学习手册之内部方法、操作符重载和对象生命周期

    在上一篇文章中,我们介绍了 Python 的类和继承,现在我们介绍 Python 的内部方法.操作符重载和对象生命周期. 查看上一篇文章请点击:https://www.cnblogs.com/dust ...

  8. 上海Uber优步司机奖励政策(12月20日到12月27日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  9. MySql 使用explain分析查询

    今天写了个慢到哭的查询,想用explain分析下执行计划,后来发现explain也是有局限性的: EXPLAIN不会告诉你关于触发器.存储过程的信息或用户自定义函数对查询的影响情况 •EXPLAIN不 ...

  10. linq中group by 的用法

    如下代码: var dates=(from p in points group p by p.LevelId into g select new { g.Key,g });之后 你会拿到这个数组: 之 ...