BUAA 623 Chem is Try!
http://oj55.bianchengla.com/problem/623/
好久没写过题解了,昨天做了一道挺恶心的题目,贴一下代码上来。看了一下提交状况,好像我的代码挺短的了,至少我找不到比我短的代码。RE1,AC。
代码如下:
#include <cctype>
#include <cstdio>
#include <cstring>
#include <map>
#include <string>
#include <iostream>
#include <algorithm> using namespace std; const int N = ;
char buf[N], *p[];
typedef long long LL;
typedef map<string, LL> MSL;
#define x first
#define y second string get_s(int x) {
string ret = "";
ret += *(p[x]++);
while (islower(*p[x])) ret += *p[x], p[x]++;
return ret;
} int get_d(int x) {
int ret = ;
while (isdigit(*p[x])) ret = ret * + *p[x] - '', p[x]++;
return ret;
} MSL merge(MSL a, MSL b) {
MSL c;
for (MSL::iterator mi = a.begin(); mi != a.end(); mi++) c[mi->x] += mi->y;
for (MSL::iterator mi = b.begin(); mi != b.end(); mi++) c[mi->x] += mi->y;
return c;
} void print(MSL &a) { for (MSL::iterator mi = a.begin(); mi != a.end(); mi++) cout << mi->x << '~' << mi->y << ' '; cout << endl; }
void multiply(MSL &a, LL p) { for (MSL::iterator mi = a.begin(); mi != a.end(); mi++) mi->y *= p; } MSL dfs(int x, char end) {
MSL cur;
//cout << x << ' ' << p[x] << endl;
while (*p[x] && *p[x] != end && *p[x] != ')') {
//cout << x << ' ' << *p[x] << endl;
if (*p[x] == '+') { p[x]++; continue; }
if (isdigit(*p[x])) {
int t = get_d(x);
MSL tmp = dfs(x, '+');
multiply(tmp, t);
cur = merge(cur, tmp);
} else {
if (*p[x] == '(') {
p[x]++; MSL tmp = dfs(x, ')');
if (*p[x] == ')') p[x]++;
if (isdigit(*p[x])) multiply(tmp, get_d(x));
cur = merge(cur, tmp);
} else {
string s = get_s(x);
if (isdigit(*p[x])) cur[s] += get_d(x);
else cur[s]++;
}
}
}
return cur;
} int main() {
//freopen("in", "r", stdin);
while (~scanf("%s", buf)) {
p[] = p[] = buf;
while (*p[] != '=') p[]++; *(p[]++) = ;
MSL ans1, ans2, tmp;
while () {
tmp = dfs(, '+');
ans1 = merge(ans1, tmp);
if (*p[] == ) break;
p[]++;
//cout << p[0] << endl;
}
while () {
tmp = dfs(, '+');
ans2 = merge(ans2, tmp);
if (*p[] == ) break;
p[]++;
//cout << p[1] << endl;
}
MSL::iterator m1 = ans1.begin(), m2 = ans2.begin();
//print(ans1); print(ans2);
while () {
if (m1 == ans1.end()) break;
if (m2 == ans2.end()) break;
if (*m1 != *m2) break;
m1++, m2++;
}
m1 == ans1.end() && m2 == ans2.end() ? puts("YES") : puts("NO");
}
return ;
}
——written by Lyon
BUAA 623 Chem is Try!的更多相关文章
- Buaa菜鸡从今天好好学打码,好好学数学,好好学英语,好好打篮球,好好锻炼,好好吃饭,好好... 好好找女朋友!
新链接: https://iamparasite.github.io/
- #CSDN刷票门# 有没有人在恶意刷票?CSDN请告诉我!用24小时监控数据说话!
特别声明: 此次并非针对其他参与2013中国十大优秀开源项目的同行,体系有漏洞要谴责的是制定规则并从中获益但不作为的权贵,草根们制定不了规则但可发现和利用漏洞,这是程序员应有反叛精神没错.但被作为道具 ...
- BUAA & ICT 夏令营之旅
我还只有二十几岁,总应该相信点什么吧. ================================ 7.10午后坐火车赶到北京.一路上火车行驶在茫茫云海里.车窗外的世界是这样子的:一片广袤的原野 ...
- 開賣!下集 -- ASP.NET 4.5 專題實務(II)-範例應用與 4.5新功能【VB/C# 雙語法】
開賣!下集 -- ASP.NET 4.5 專題實務(II)-範例應用與 4.5新功能[VB/C# 雙語法] 我.....作者都沒拿到書呢! 全台灣最專業的電腦書店 -- 天瓏書局 已經開賣了! 感謝天 ...
- 【BUAA软件工程】第一次阅读作业
BUAA软件工程 第一次阅读作业 项目 内容 这个作业属于哪个课程? 北航软工 这个作业的要求在哪里? 第一次个人作业 我在这个课程的目标是? 学习高效严谨的软件工程开发过程,建立团队意识 这个作业在 ...
- [BUAA软工]第1次阅读
[BUAA软工]第1次阅读 本次作业所属课程: 2019BUAA软件工程 本次作业要求: 第1次个人作业 我在本课程的目标 熟悉和实践软件工程流程,适应团队开发 本次作业的帮助 帮助理解<构建之 ...
- [BUAA软工]第一次博客作业---阅读《构建之法》
[BUAA软工]第一次博客作业 项目 内容 这个作业属于哪个课程 北航软工 这个作业的要求在哪里 第1次个人作业 我在这个课程的目标是 学习如何以团队的形式开发软件,提升个人软件开发能力 这个作业在哪 ...
- 线上问题!----------org.apache.catalina.connector.ClientAbortException: java.io.IOException: Broken pipe
1.问题出现 昨晚项目在上线的时候因为推广的原因,新增的大量请求.在八点的时候. org.apache.catalina.connector.ClientAbortException: java.io ...
- [BUAA软工]第零次博客作业---问题回答
[BUAA软工]第0次博客作业 项目 内容 这个作业属于哪个课程 北航软工 这个作业的要求在哪里 第0次个人作业 我在这个课程的目标是 学习如何以团队的形式开发软件,提升个人软件开发能力 这个作业在哪 ...
随机推荐
- Node.js Error: Cannot find module express的解决办法(转载)
1.全局安装express框架,cmd打开命令行,输入如下命令: npm install -g express express 4.x版本中将命令工具分出来,安装一个命令工具,执行命令: npm in ...
- C# 多线程操作之异步委托
标签: 多线程任务nullstringhtml工作 2012-06-29 23:00 1276人阅读 评论(0) 收藏 举报 分类: C/C++/C#/dotnet(126) 目录(?)[+] ...
- Eclipse安装Spket插件
Eclipse安装Spket插件 1.在线安装,地址:Spket - http://www.agpad.com/update 2.下载插件包安装, 地址:http://www.spket.com/
- grpc入门2
rpc-gateway使用(同时提供rpc和http接口) 介绍第三方库 https://github.com/grpc-ecosystem/grpc-gateway 在grpc之上加一层代理并转发, ...
- 多机MySQL一主双从详细安装主从复制
多机MySQL一主双从详细安装 一.复制的工作原理 要想实现AB复制,那么前提是master上必须要开启二进制日志 1.首先master将数据更新记录到二进制日志文件 2.从slave start开始 ...
- Git.之.最小化配置
Git.之.最小化配置 做一个全局的用户配置,便于以后提交代码等,记录当前操作的用户. ## 添加配置 # git config [--local | --global | --system] use ...
- python OneHot编码
- SASS在HTML5移动应用开发中的应用方法
一.什么是SASS SASS是一种CSS的开发工具,提供了许多便利的写法,大大节省了设计者的时间,使得CSS的开发,变得简单和可维护. 本文总结了SASS的主要用法.二.安装和使用 2.1 安装 SA ...
- HR招聘_(八)_招聘方法论(面试环节·问题设计)
基本情况: 您目前是在职还是离职?最快的到岗时间是? 目前的薪资情况如何,期望薪资是? 您是哪里人,单身吗? 动机判断: 您看机会主要考虑哪些因素? 最重要的是什么? 未来两三年的职业规划是? 您住在 ...
- selenium(2):环境搭建完成后,初步运行遇到的问题
检验是否搭建成功. . 问题一:运行时候,报错:请停用以开发者模式运行的扩展程序 出现错误如下: 原因:chromedriver的版本号过低了. 解决办法:应该安装与chrome版本对应的chrome ...