UVA327
模拟
这个问题的任务是求解一组c语言里的表达式,但是你不需要知道c语言是怎么解决这个问题!
每一行一个表达式,每个表达式的组成不会超过110个字符.
待求解的表达式只包含一个int类型变量和一个组有限的操作;
表达式内不包含常量.
在我们简单的表达内将可能出现26个变量,变量名从‘a’到‘z’(小写字母形式).
在每个表达式开始前,这26个变量的值从1到26,(a=1,b=2.......z=26),
每个变量在一个表达式里面只出现一次,可能有许多变量没有被使用.
二元操作符+和-号可能在表达式内出现,计算法则根据通常的理解.
因此这个表达式a+c-d+b的值等于2(计算方式,1+3-4+2=2).
表达式内还可能出现++,--操作符.
++和--是一元操作符(只要一个操作数),++和--出现的任意变量的前面和后面.
当++操作符在变量前面时,将变量的值加1在变量拿来决定整个表达值前(使用前+1).
因此,表达式++ c - b 的值等于2,c的值加到4在计算整个表达期间(c=3,++c=4).
当++操作符出现在表达后面时,在变量拿来决定整个表达的值后加1(使用后再+1).
因此表达式 c ++ - b的值是1,但是c在计算完整个表达式后将会增加,它的值是4.
--操作符的和++操作符一样,同样能出现在变量的前面或者后面,用于将一个变量减1,
--操作放在变量的前面或后面的意义和++操作符一样,
因此表达式 --c + b--的值等于4,
计算完表达式后,c的值等于2,b的值等于1.
下面是其他算法规则用于解释++和--操作,我们只解释++(--的意义一样):
1.标识前面有++操作符的变量,写一个简单的赋值语句用于增加每个变量的值,然后在表达式使用前移除++操作符.
2.同样的方式,标识后面有++操作符的变量,写一个简单的赋值语句用于增加每个变量的值,然后在表达式使用后移除++操作符.
3.现在没有任何++操作符在每个变量前面和后面,写一个语句对剩余的表达式求解,先写入步骤1,然后写入步骤2.
Write the statement that evaluates the remaining expression after those statements written in step 1, and before those written in step 2.
4.执行顺序,执行第一步产生的语句,然后执行第三步产生的语句,最后执行第二步产生的语句
适用说明,求解表达式 ++ a + b ++等于计算 a=a+1(第一步算法),表达式=a+b(来自第三步算法),b=b+1(第二步算法),表达最后的值等于=a+b(4),
输入:
你的程序读取表达式,一个表达式一行,直到文件结束.
输出:
打印每个你读取的完整表达式,在不同的行中打印表达式的值,在表达式求解后每个变量的值,没有使用过的变量不用展示,
下面是期望输出的输出样例格式
每个表达式内的空格在求解时应该被忽略,不清楚的表达式不会出现在输入文件内,
比如表达式a+++b是不清楚的(原因:表达式可以当成a++ +b 或者 a + ++b).
同样,++和--操作符不会同时出现在同一个变量的前面和后面.因此类似表达式++a++的表达式不会出现在输入数据内.
#include<stdio.h>
#include<iostream>
#include <strstream>
#include<memory.h>
using namespace std;
struct Node
{
int index;
char op;
}; void init(int* const a);
bool isLetter(char a); int s1(string str, int used[], int a[])
{
int sum = 0;
int length = str.length();
char op = ' ';
for (int i = 0; i < length; i++)
{
char c = str.at(i);
if (c == ' ')
continue;
if (isLetter(c))
{
used[c - 'a'] = 1;
if (op == '-')
sum -= a[c - 'a'];
else if (op == '+')
sum += a[c - 'a'];
else if (op == ' ')
sum += a[c - 'a'];
op = ' ';
}
else
{
if (c == '-')
{
char aop = str.at(i + 1);
if (aop == c)
{
if (i > 0 && isLetter(str.at(i - 1)))
{
//a++
a[str.at(i - 1) - 'a']--;
}
else
{
//++a
a[str.at(i + 2) - 'a']--;
}
i++;
}
else
op = c;
}
else if (c == '+')
{
char aop = str.at(i + 1);
if (aop == c)
{
if (i > 0 && isLetter(str.at(i - 1)))
{
//a++
a[str.at(i - 1) - 'a']++;
}
else
{
//++a
a[str.at(i + 2) - 'a']++;
}
i++;
}
else
op = c;
}
}
}
return sum;
}
int main()
{
//freopen("d:\\1.txt", "r", stdin);
string str;
while (getline(cin, str))
{
string str2 = "";
int length = str.length();
for (int i = 0; i < length; i++)
{
if (str.at(i) == ' ')
continue;
str2 = str2 + str.at(i);
}
int a[27];
int used[27];
memset(used, 0, sizeof(int) * 27);
init(a);
int sum = 0;
sum = s1(str2, used, a);
cout << "Expression: " << str << endl;
cout << " value = " << sum << endl;
for (int i = 0; i < 26; i++)
{
if (used[i] == 1)
cout << " " << (char) ('a' + i) << " = " << a[i] << endl;
}
}
} void init(int* const a)
{
for (int i = 0; i < 26; i++)
{
a[i] = i + 1;
}
} bool isLetter(char a)
{
return a >= 'a' && a <= 'z';
}
UVA327的更多相关文章
- uva-327
题意:给出一个C语言加减法表达式,求出这个表达式的最终结构,以及各个变量的值,每个变量保证至出现一次,保证输入的字符串合法: 输入:一串包含+.-和小写的26个英文字母: 输出:表达式的结果,以及表达 ...
- 基础数据结构之(Binary Trees)
从头开始刷ACM,真的发现过去的很多漏洞,特别越是基础的数据结构,越应该学习得精,无论是ACM竞赛,研究生考试,还是工程上,对这些基础数据结构的应用都非常多,深刻理解非常必要.不得不说最近感触还是比较 ...
随机推荐
- 度限制最小生成树 POJ 1639 贪心+DFS+prim
很好的解题报告: http://blog.csdn.net/new_c_yuer/article/details/6365689 注意两点: 1.预处理环中权值最大的边···· 2.可以把去掉度限制后 ...
- 强连通分量【k 算法、t 算法】
连通分量就是一个各个顶点能互相达到的图 无向图的连通分量选取任意一个顶点使用DFS遍历即可,遍历完所有顶点所需的DFS的次数就是连通分量的数量 有向图的强连通分量由于是有向的[从A点开始DFS能访问到 ...
- hdu2060-2062
hdu 2060 斯诺克,读懂题意直接模拟 #include<stdio.h> int main(){ int N; ]; a[]=; ;i<=;i++){ a[i]=(-i)*i/ ...
- Struts2重新学习之自定义拦截器(判断用户是否是登录状态)
拦截器 一:1:概念:Interceptor拦截器类似于我们学习过的过滤器,是可以再action执行前后执行的代码.是web开发时,常用的技术.比如,权限控制,日志记录. 2:多个拦截器Interce ...
- JS前端数据多条件筛选(商品搜索)
有时候也会需要在前端进行数据筛选,增强交互体验.当数据可用的筛选条件较多时,把逻辑写死会给后期维护带来很大麻烦.下面是我自己写的一个简单的筛选器,筛选条件可以根据数据包含的字段动态设置. 仿照京东的筛 ...
- 剑指offer-第一个只出现一次的字符-字符串和数组
用到的算法都是像冒泡排序,直接选择排序,插入排序 每趟进行处理,这个趟是没有什么实际意义的 变量j一次从头走到尾进行一次循环枚举遍历扫描 一.题目:第一个只出现一次的字符 题目:在字符串中找出第一个只 ...
- USB设备驱动_WDS
1. usb_alloc_dev中的 bus_type 中指定了匹配函数,和uevent中的环境参数. ====>不同的bus_type的匹配函数可能是不同的,uevent的环境变量参数也可能是 ...
- 使用php的curl根据关键词爬取百度搜索结果页
http://bbs.csdn.net/wap/topics/390938327 正则表达式匹配Html标签 查找所有的TD区域(最短):<td\s*.*>\s*.*<\/td& ...
- xml时间配置
这些星号由左到右按顺序代表 : * * * * * * * 秒 分 时 日 月 周 年 序号 说明 是否必填 允许填写的值 允许的通配符 秒 是 0-59 , - * / 分 是 0-59 , - * ...
- python、java大作战,python测试dubbo接口
很多小伙伴都反映公司要求测dubbo(dubbo是一个java的分布式开源框架)接口,不会写java代码,怎么测,能不能用python来调dubbo接口.当然是可以的了,最近研究了一下,很简单,分享给 ...