这题怎么这么毒瘤...

一开始我想转后缀表达式来计算,后来发现有负数...弃疗。

递归求解又发现会有多余括号,我觉得不行...

实在是毒瘤啊!

 #include <cstdio>
#include <iostream>
#include <string>
typedef long long LL;
std::string s; bool isop(char c) {
if(c == '+') return ;
if(c == '-') return ;
if(c == '*') return ;
if(c == '/') return ;
if(c == '^') return ;
return ;
} LL pow(LL a, LL b) {
LL ans = ;
for(int i = ; i <= b; i++) {
ans *= a;
}
return ans;
} LL solve(int l, int r) {
int f = ;
int pos1 = -, pos2 = -, pos3 = -;
for(int i = l; i <= r; i++) {
if(isop(s[i]) && (!f)) {
if(s[i] == '+' || s[i] == '-') {
pos1 = i;
}
else if(s[i] == '*' || s[i] == '/') {
pos2 = i;
}
else {
pos3 = i;
}
}
else if(s[i] == '(') f++;
else if(s[i] == ')') f--;
} if(f > ) {
LL temp = solve(l + , r);
return temp;
} if(f < ) {
LL temp = solve(l, r - );
return temp;
} if(pos1 > l) {
if(s[pos1] == '+') {
return solve(l, pos1 - ) + solve(pos1 + , r);
}
else {
return solve(l, pos1 - ) - solve(pos1 + , r);
}
}
else if(pos2 != -) {
if(s[pos2] == '*') {
return solve(l, pos2 - ) * solve(pos2 + , r);
}
else {
return solve(l, pos2 - ) / solve(pos2 + , r);
}
}
else if(pos3 != -) {
return pow(solve(l, pos3 - ), solve(pos3 + , r));
}
else if(s[l] == '(' && s[r] == ')'){
return solve(l + , r - );
}
else {
LL ans = ;
int f = ;
while(s[l] == '(') l++;
if(s[l] == '-') {
f = -;
l++;
}
for(int i = l; i <= r; i++) {
if(s[i] == ')') break;
ans = ans * + s[i] - '';
}
return ans * f;
}
} int main() {
std::cin >> s;
printf("%lld", solve(, s.size() - ));
return ;
}

AC代码

tyvj/joyoi 1043 表达式计算4的更多相关文章

  1. .NET平台开源项目速览(8)Expression Evaluator表达式计算组件使用

    在文章:这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑)中,给大家初步介绍了一下Expression Evaluator验证组件.那里只是概述了一下,并没有对其使用和强大功能做 ...

  2. C# - 二叉树表达式计算

    很早以前就写过双栈的表达式计算. 这次因为想深入学一下二叉树,网上都是些老掉牙的关于二叉树的基本操作. 感觉如果就学那些概念,没意思也不好记忆.于是动手写了一个表达式计算的应用例子. 这样学习印象才深 ...

  3. C#动态表达式计算

    C#动态表达式计算 应该有不少人开发过程中遇到过这样的需求,我们直接看图说话: 如上图所示,其中Entity为实体类,其中包括五个属性,该五个属性的值分别来自于数据库查询结果: 用户通过可视化界面进行 ...

  4. C#动态表达式计算(续2)

    上两篇废话太多,这一次我就不多说了,由于代码比较简单,可以直接从https://github.com/scottshare/DynamicExpress.git地址下载. 以下说明一下使用方法: Dy ...

  5. 栈应用之 后缀表达式计算 (python 版)

    栈应用之 后缀表达式计算 (python 版) 后缀表达式特别适合计算机处理 1.  中缀表达式.前缀表达式.后缀表达式区别  中缀表达式:(3 - 5) * (6 + 17 * 4) / 3 17 ...

  6. C++实现 逆波兰表达式计算问题

    C++实现 逆波兰表达式计算问题 #include <iostream> #include <string> using namespace std; class Stack ...

  7. 算法笔记_044:表达式计算求值(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 输入一个只包含加减乖除和括号的合法表达式,求表达式的值.其中除表示整除. 输入格式 输入一行,包含一个表达式. 输出格式 输出这个表达式的 ...

  8. Fel表达式计算引擎学习

    转载原文地址:Fel是轻量级的高效的表达式计算引擎 Fel的问题 Fel的问题 Fel是轻量级的高效的表达式计算引擎 Fel在源自于企业项目,设计目标是为了满足不断变化的功能需求和性能需求. Fel是 ...

  9. 蓝桥杯 算法训练 ALGO-156 表达式计算

    算法训练 表达式计算   时间限制:1.0s   内存限制:256.0MB 问题描述 输入一个只包含加减乖除和括号的合法表达式,求表达式的值.其中除表示整除. 输入格式 输入一行,包含一个表达式. 输 ...

随机推荐

  1. Java案例-用户注册邮箱绑定激活功能实现

    <–start–> 需求描述:当客户打开收到邮箱激活码的邮件,点击激活链接,正确填写激活码后就会完成邮箱激活的步骤. 在后台编程代码编写中,有以下几个要点: ① 接收客户的手机号码和邮箱激 ...

  2. CentOS7装Tomcat

    有两种安装方式:(1)yum 命令  (2)安装包 本次采用第二种方式: 1.windos下载apache-tomcat-7.0.73.tar.gz安装包 2.通过WinSCP传到linux下(本次放 ...

  3. 本地git连接远程github

    git要连接GitHub仓库,是通过SSH加密连接的,所以必须要创建SSH key ssh-key -t rsa -C "youremail@example.com" 这里邮箱必须 ...

  4. Serialize a Long as a String

    今天在写接口的时候,用postman测试,返回数据与数据库一一对应,但是给前端返回的结果,除了主键id以外,其他都一样,如下 postman: { "unitPrice": nul ...

  5. excel 公式 insert 语句

    ="insert into tb_fdn_deviceaccount (zdmc,czmc,sbbh,sbmc,SZCS,SBFLMC,SBLXMC,SBGG,SBYZ,SBJZ,SBXH, ...

  6. 1.docker 数据卷的备份和恢复(非大数据量)

    在生产环境中使用 Docker,很多时候需要对数据进行持久化,或者进行容器间的数据共享. 容器中的管理数据主要有两种方式: 数据卷 (Data Volumes): 容器内数据直接映射到本地主机环境: ...

  7. Newton方法

    Newton方法主要解决无等式约束和等式约束的最优化方法. 1.函数进行二阶泰勒展开近似 Taylor近似函数求导等于0进而得到Newton步径.(搜索方向) 2.Newton减量(停止条件) 当1/ ...

  8. NotBacon

    What's It Do? The application consists of two components: A Custom Vision Service project that allow ...

  9. 源码分析: 图片加载框架Picasso源码分析

    使用: Picasso.with(this) .load("http://imgstore.cdn.sogou.com/app/a/100540002/467502.jpg") . ...

  10. [IOI2018]高速公路收费——二分查找+bfs

    题目链接: IOI2018highway 题目大意:给出一张$n$个点$m$条边的无向图,并给出一对未知的起点和终点,每条边都有两种边权$A$和$B$(每条边的$A$和$B$都分别相同),每次你可以设 ...