hihoCoder 简单计算器
数据结构的入门题,理解倒是不复杂,用两个栈就行(一个存数字一个存符号)。对于我这样的弱弱没事练练编码能力还是不错的。
注意运算优先级即可。(过两天回科大了,下次再做题也不知道何时,ACM生涯两铜收场orz)
题目链接:
http://hihocoder.com/contest/hihointerview11/problem/3
代码:
- #include <bits/stdc++.h>
- using namespace std;
- typedef long long int64;
- stack<int64> sn;
- stack<char> sc;
- const int maxn = + ;
- char str[maxn];
- char op[] = { '+', '-', '*', '/', '(', ')', '#' };
- int getOpId(char op){
- if(op == '+')
- return -;
- else if(op == '-')
- return -;
- else if(op == '*')
- return -;
- else if(op == '/')
- return -;
- else if(op == '(' )
- return -;
- else if(op == ')' )
- return -;
- else if(op == '#')
- return -;
- else if(op == '&')
- return -;
- }
- vector<int64> v;
- int getPrio(char op){
- switch(op){
- case '+': return ;
- case '-': return ;
- case '*': return ;
- case '/': return ;
- case '(': return ;
- case '&': return ;
- default: return ;
- }
- }
- int64 cal(int64 a, int64 b, char opt){
- if(opt == '+'){
- return a+b;
- }else if(opt == '-'){
- return a-b;
- }else if(opt == '*'){
- return a*b;
- }else if(opt == '/'){
- return a/b;
- }
- }
- int main(void){
- scanf("%s", str);
- int len = strlen(str);
- str[len++] = '#';
- for(int i = ; i < len; ++i){
- if('' <= str[i] && str[i] <= ''){
- int64 t = ;
- while('' <= str[i] && str[i] <= ''){
- t = t * + (str[i] - '');
- i++;
- }
- i--;
- v.push_back(t);
- }else{
- v.push_back(getOpId(str[i]));
- }
- //cout << v.back() << " ";
- }
- //cout << endl;
- int sz = v.size();
- sc.push('&');
- for(int i = ; i < sz; ++i){
- if(v[i] >= ){
- sn.push(v[i]);
- //cout << "push " << v[i] << endl;
- }else{
- char c = op[-v[i]-];
- if(c == '('){
- sc.push('(');
- //cout << "push " << '(' << endl;
- }else if(c == ')'){
- while(sc.top() != '('){
- int64 b = sn.top(); sn.pop();
- int64 a = sn.top(); sn.pop();
- char opt = sc.top(); sc.pop();
- sn.push(cal(a, b, opt));
- //cout << "cal " << a << " " << opt << " " << b << endl;
- }
- sc.pop();
- //cout << "pop " << '(' << endl;
- }else{
- int prio1 = getPrio(c);
- int prio2;
- while(prio1 <= (prio2 = getPrio(sc.top()))){
- //cout << "prio1: " << prio1 << " prio2: " << prio2 << endl;
- int64 b = sn.top(); sn.pop();
- int64 a = sn.top(); sn.pop();
- char opt = sc.top(); sc.pop();
- sn.push(cal(a, b, opt));
- //cout << "cal " << a << " " << opt << " " << b << endl;
- }
- sc.push(c);
- //cout << "push " << c << endl;
- }
- }
- }
- //cout << "haha" << endl;
- printf("%lld\n", sn.top());
- return ;
- }
- /**
- 5*(3+8*2)-(5+6*2-7)*2
- 100*(2+12)-(20/3)*2
- (8+2*3/4-4)*(3-2+5/2*3)*(3-4+3)/6
- */
hihoCoder 简单计算器的更多相关文章
- 1.C#WinForm基础制作简单计算器
利用c#语言编写简单计算器: 核心知识点: MessageBox.Show(Convert.ToString(comboBox1.SelectedIndex));//下拉序号 MessageBox.S ...
- 菜鸟学Android编程——简单计算器《一》
菜鸟瞎搞,高手莫进 本人菜鸟一枚,最近在学Android编程,网上看了一些视频教程,于是想着平时手机上的计算器应该很简单,自己何不尝试着做一个呢? 于是就冒冒失失的开撸了. 简单计算器嘛,功能当然很少 ...
- PAT 06-1 简单计算器
想看一般简单计算器实现的看客不好意思了,这不是你想要点东西,此处题设为“只能进行加减乘除”.“都是整数”.”优先级相同“和"从左到右".此题来自PAT(http://www.pat ...
- php大力力 [005节] php大力力简单计算器001
2015-08-22 php大力力005. php大力力简单计算器001: 上网看视频,看了半天,敲击代码,如下: <html> <head> <title>简单计 ...
- PHP实现简单计算器
<!--简单的计算器--> <!DOCTYPE html> <html> <head> <title>PHP实现简单计算器</titl ...
- c#部分---网吧充值系统;简易的闹钟;出租车计费;简单计算器;对战游戏;等额本金法计算贷款还款利息等;随机生成10个不重复的50以内的整数;推箱子;
网吧充值系统namespace ConsoleApplication1 { class Program { struct huiyuan { public string name; public st ...
- JavaWeb学习记录(二十)——Model1模式(javaBean+jsp)实现简单计算器案例
¨JSP技术提供了三个关于JavaBean组件的动作元素,即JSP标签,它们分别为: ¨<jsp:useBean>标签:用于在JSP页面中查找或实例化一个JavaBean组件. ¨< ...
- 一个用WPF做的简单计算器源代码
一.界面设计XAML代码 <Window x:Class="fengjisuanqi.MainWindow" xmlns="http://schemas.micro ...
- hdu 1237 简单计算器
题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1237 简单计算器 Description 读入一个只包含 +, -, *, / 的非负整数计算表达式, ...
随机推荐
- dos2unix xxx.sh
前几天写了一个Linux的自动化脚本,没有使用变量,就是一些Linux命令的集合 今天试着把一些相同的字段提出来用变量表示,然后在Linux里运行,就发现一直在报错: : command not fo ...
- 【sqli-labs】 less47 GET -Error based -String -Order By Clause(GET型基于错误的字符型Order By从句注入)
http://192.168.136.128/sqli-labs-master/Less-47/?sort=1 改变sort的值,结果仍然是order by 1的结果 http://192.168.1 ...
- What is gradle sync in Android Studio?
What is it? And what does it do? Gradle sync is a gradle task that looks through all of your depende ...
- js的StringBuffer类
function StringBuffer(str){ var arr = []; str = str || ""; arr.push(str); this.append = fu ...
- 原型链、构造函数、箭头函数、se6数组去重
原型链 例子如下: var arr = [1, 2, 3]; 其原型链为:arr ----> Array.prototype ----> Object.prototype ----> ...
- 51nod1006 -最长公共子序列Lcs【动态规划】
给出两个字符串A B,求A与B的最长公共子序列(子序列不要求是连续的). 比如两个串为: abcicba abdkscab ab是两个串的子序列,abc也是,abca也是,其中abca是这两个字符串最 ...
- trycatch中return语句如何执行
测试代码如下: package reviewTest; /** * @ClassName: ReturnTest * @Description: 测试return在trycatch中的执行 * @au ...
- C#学习笔记_09_构造方法/函数
09_构造方法/函数 代码案例 作用:构造函数主要是用来创建对象时为对象赋初值来初始化对象:总与new运算符一起使用在创建对象的语句中,例如A a=new A(); 特点: 构造函数具有和类一样的名称 ...
- hadoop-hdp-ambari离线安装记录
一.系统准备 1. 创建user——ambari 2.关闭防火墙 redhat6: chkconfig iptables off /etc/init.d/iptables stop redhat7: ...
- 2017 Multi-University Training Contest - Team 4 Classic Quotation
Classic Quotation Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 524288/524288 K (Java/Othe ...