Codeforces 552E Vanya and Brackets(枚举 + 表达式计算)
题目链接 Vanya and Brackets
题目大意是给出一个只由1-9的数、乘号和加号组成的表达式,若要在这个表达式中加上一对括号,求加上括号的表达式的最大值。
我们发现,左括号的位置肯定是最左端或者某个乘号右边,右括号的位置肯定是最右段或者某个乘号左边。
而乘号最多只有15个,那么暴力枚举就可以了。
#include <bits/stdc++.h> using namespace std; #define rep(i, a, b) for (int i(a); i <= (b); ++i)
#define dec(i, a, b) for (int i(a); i >= (b); --i) typedef long long LL; vector <int> pos; LL calc(const string &str){ stack <LL> num;
stack <char> op; for (int i = 0, slen = str.length(); i < slen; ++i) {
if (str[i] == ')'){
while (op.top() != '('){
LL tmp = num.top();
num.pop();
if (op.top() == '*') num.top() *= tmp;
else if (op.top() == '+') num.top() += tmp;
op.pop();
}
op.pop();
continue;
}
if (isdigit(str[i])) num.push(str[i] - '0');
else if (str[i] == '+' && !op.empty() && op.top() == '*'){
while (!op.empty() && op.top() == '*'){
LL tmp = num.top();
num.pop();
num.top() *= tmp;
op.pop();
}
op.push(str[i]);
}
else op.push(str[i]);
}
while(!op.empty()){
LL tmp = num.top();
num.pop();
if(op.top() == '*') num.top() *= tmp;
else if(op.top() == '+') num.top() += tmp;
op.pop();
}
return num.top();
} int main(){ string str;
cin >> str;
pos.push_back(-1);
int slen = str.length();
for (int i = 1; i < slen; i += 2) if (str[i] == '*') pos.push_back(i);
pos.push_back(slen);
slen = pos.size(); LL ret = INT_MIN;
rep(i, 0, slen - 2)
rep(j, i + 1, slen - 1){
string s = str;
s.insert(pos[i] + 1, 1, '(');
s.insert(pos[j] + 1, 1, ')');
ret = max(ret, calc(s));
}
cout << ret << endl;
return 0;
}
Codeforces 552E Vanya and Brackets(枚举 + 表达式计算)的更多相关文章
- Codeforces 552E - Vanya and Brackets【表达式求值】
		
给一个只有加号和乘号的表达式,要求添加一对括号使得最后结果最大.表达式长度5000,乘号最多12个,表达式中数字只有1位. 左括号一定在乘号右边,右括号一定在乘号左边,因为如果不是这样的话,一定可以调 ...
 - CodeForces - 552E Vanya and Brackets
		
Vanya and Brackets Time Limit: 1000MS Memory Limit: 262144KB 64bit IO Format: %I64d & %I64u ...
 - CodeForces - 552E  Vanya and Brackets  —— 加与乘运算的组合
		
题目链接:https://vjudge.net/contest/224393#problem/E Vanya is doing his maths homework. He has an expres ...
 - CodeForces  677D. Vanya and Treasure  枚举行列
		
677D. Vanya and Treasure 题意: 给定一张n*m的图,图上每个点标有1~p的值,你初始在(1,1)点,你必须按照V:1,2,3...p的顺序走图上的点,问你如何走时间最少. 思 ...
 - Vanya and Brackets
		
Vanya and Brackets Time Limit:1000MS Memory Limit:262144KB 64bit IO Format:%I64d & %I64u ...
 - .NET平台开源项目速览(8)Expression Evaluator表达式计算组件使用
		
在文章:这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑)中,给大家初步介绍了一下Expression Evaluator验证组件.那里只是概述了一下,并没有对其使用和强大功能做 ...
 - C# - 二叉树表达式计算
		
很早以前就写过双栈的表达式计算. 这次因为想深入学一下二叉树,网上都是些老掉牙的关于二叉树的基本操作. 感觉如果就学那些概念,没意思也不好记忆.于是动手写了一个表达式计算的应用例子. 这样学习印象才深 ...
 - C#动态表达式计算
		
C#动态表达式计算 应该有不少人开发过程中遇到过这样的需求,我们直接看图说话: 如上图所示,其中Entity为实体类,其中包括五个属性,该五个属性的值分别来自于数据库查询结果: 用户通过可视化界面进行 ...
 - C#动态表达式计算(续2)
		
上两篇废话太多,这一次我就不多说了,由于代码比较简单,可以直接从https://github.com/scottshare/DynamicExpress.git地址下载. 以下说明一下使用方法: Dy ...
 
随机推荐
- SQLyog连接数据库 提示错误plugin caching_sha2_password could not be loaded
			
1.打开mysql cmd 2.执行语句 ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER; # ...
 - Xcode 6 创建 Empty Application
			
1.创建一个 Single View Application: 2.删除工程目录下的 Main.storyboard 和 LaunchScreen.xib: 3.打开 Supporting Files ...
 - Java 局部变量未初始化会报错,局部变量没有初始值,成员变量有初始值
			
Java 成员变量有初始值,而局部变量没有初始值. 如下所示,代码不能编译通过 public static void main(String[] args){ String s; Sy ...
 - (42)zabbix使用IT services 了解服务器SLA整体情况
			
什么是IT Services 服务器或者某项服务.业务的可用率,不懂技术的上级领导会过问最近服务器可用率如何.所有api的状况怎么样? 通常一些技术人员会说负载怎么样,哪些cpu使用率怎么样,硬盘使用 ...
 - Lecture1 实验过程模型
			
Part 1 基本概念 因变量:待检验理论重点关注的,受多个变量影响的变量.(实际考察的,结果) 自变量:影响因变量变化的变量. 因子:重点关注的自变量. 控制变量(control variables ...
 - 组队赛Day1第一场 GYM 101350A - Sherlock Bones (DP)
			
[题意] 给你一个01串.f(i,j)定义为区间[i,j]内1的个数,求区间 [i,j,k] 中 f(i,j) =f(j,k) 的情况的子串总数,要求str[j]=='1'. (题意描述引自Ilook ...
 - FX3 DMA生产者消费者ID代表的含义
			
在开发FX3的时候,觉得赛普拉斯的库注释太少,很多时候无法理解代码含义.由于使用DMA,需要理解DMA生产者消费者代表的含义,经过多方查找,决定记录下来. 在cyu3dma.h中对SocketID进行 ...
 - 基于顺序链表的栈的顺序存储的C风格实现
			
头文件: #ifndef _SEQSTACK_H_ #define _SEQSTACK_H_ typedef void SeqStack; //创建一个栈 SeqStack* SeqStack_Cre ...
 - 关于logging模块重复问题
			
logger对象配置 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 import logging # 获取一个新日志logger = ...
 - VC调试入门
			
概述调试是一个程序员最基本的技能,其重要性甚至超过学习一门语言.不会调试的程序员就意味着他即使会一门语言,却不能编制出任何好的软件.这里我简要的根据自己的经验列出调试中比较常用的技巧,希望对大家有用. ...