题目描述

$SLON$是一个调皮的学生,为了让他静下心来,老师给他出了一道数学题:
给定表达式$A$,$A$中含有变量$x$和$+,-,*,(,)$这些符号,括号成对出现,一个算术运算符均对应两个操作数,不能出现$(-5)$或者$(4+-5)$等,乘号不能省略,并且表达式$A$中$x$只能是一阶,即一阶表达式:
合理表达式
$$A=\left\{\begin{array}{c}5 + x∗(3 + 2)\\x + 3∗x + 4∗(5 + 3∗(2 + x−2∗x))\end{array}\right.$$
不合理表达式
$$A=\left\{\begin{array}{c}5∗(3 + x∗(3 + x))\\x∗(x + x∗(1 + x))\end{array}\right..$$
求$A(mod)M==P$时,最小的 $x$.

输入

第一行输入一个表达式$A,(1≤|A|≤100000)$。
第二行输入两个整数$P (0 ≤ P ≤ M −1)、M (1 ≤ M ≤ 1000000)$。

样例一
5+3+x
9 10
样例二
20+3+x
0 5 样例三
3*(x+(x+4)*5)
1 7

输出

输出最小的非负$x$。

样例一
1
样例二
2
样例三
3

题解

一道十分经典的字符串处理四则运算题。
可以作为处理四则运算的典例。
首先,我们应该先搞清楚这个题的难点到底是什么。
其实看过题目都应该知道,处理字符串应该是这个题的核心难点
至于什么取模什么相等的都去死吧,我要用爆搜之剑审判你
那么,这个有四则运算在其中的字符串应该如何处理呢?
那么,这里就有了许多种处理字符串的方式:

1.保持原有中则表达式,利用栈处理字符串
2.将中则表达式转为后缀表达式,利用栈与递归处理
3.(实在不知道这种思路叫什么)将每一个数字与一个运算符绑在一起,利用递归处理字符串。
这篇文章将侧重讲解第二种方法 ~~(不然为什么把它放在最后面)~~ 
首先,我们来看一下这道题处理麻烦的原因:
 - 括号改变计算顺序
 - 字符$x$既不是运算符
 - 括号前若有$'-'$,那么括号里面的所有符号(除乘号)都要进行**反转**操作
 - $'*'$与$'+'('-')$一起时,应先计算乘号的内容
也就是说,如果我们把以上问题处理好,那么此题就迎刃而解了。
要解决以上问题,这里要用一种封装思想:
这道题题目似乎很难,但是可以浓缩为几句话
将一个四则表达式化简为$Kx+B$,且使得$$(Kx+B)modM==P$$这就是这道题的精髓。
也就是说,我们要得到的是$K$与$B$,而所谓封装,就是将每一个括号(也不一定是括号)的$K$与$R$装进一个$struct$或者是$pair$中,再用这个$struct$或者$pair$与其他的直接进行加、减、乘即可。(这句话十分重要,但若是不懂,看看代码应该也能理解)
剩下的,和一般的四则运算处理就差不多了。
那么我们定义:$pair$中的$first$为当前算式中$x$的系数,$second$为常数的值。
通过$pair$的两个数的定义,很容易就可以得出两个$pair$相加、减、乘时的具体操作。
为了更方便理解,这里我用数学符号进行推到(其实十分简单)
通过$pair$定义,令$pair_1=(K_1,B_1)$,$pair_2=(K_2,B_2)$.
那么$$pair_1±pair_2=(K_1x+B_1)±(K_2x+B_2)$$$$=>pair_{return}=(K_1±K_2,B_1±B_2)$$紧接着$$pair_1*pair_2=(K_1x+B_1)(K_2x+B_2)$$$$=>原式=K_1K_2x^2+(K_1+K_2)x+B_1B_2$$注意,因为题目保证这是一个一元一次的方程,那么$K_1$、$K_2$中必有一个为$0$,那么就不用考虑$x^2$了,那么$$pair_{return}=(K_1B_2+K_2B_1,B_1B_2)$$其他的操作就比较简单了。
下见代码。
 1 #include<cstdio>
2 #include<stack>
3 #include<cstring>
4 #include<utility>
5 using namespace std;
6 typedef long long LL;
7 typedef pair<LL,LL> pll;
8 #define mp(a,b) make_pair(a,b)
9 #define ft first
10 #define sd second
11 inline LL read(){
12 #define cg (c=getchar())
13 LL x,f=1;char c;
14 while(cg<'0'||'9'<c)if(c=='-')f=-1;
15 for(x=(c^48);'0'<=cg&&c<='9';x=(x<<1)+(x<<3)+(c^48));
16 return x*f;
17 #undef cg
18 }
19 const LL MAXL=100000;
20 char str[MAXL|1];
21 LL P,M,len;
22 pll operator+(const pll& a,const pll& b){
23 //处理两个pair相加
24 return mp((a.ft+b.ft)%M,(a.sd+b.sd)%M);
25 }
26 pll operator-(const pll& a,const pll& b){
27 return mp((a.ft-b.ft+M)%M,(a.sd-b.sd+M)%M);
28 }
29 pll operator*(const pll& a,const pll& b){
30 return mp((a.ft*b.sd+a.sd*b.ft)%M,a.sd*b.sd%M);
31 }
32 bool isnum(char c){
33 return '0'<=c&&c<='9';
34 }
35 stack<char>ch;
36 stack<pll>sta;
37 bool cmpPrio(char a,char b){
38 if(a=='('||b=='(')return 0;
39 if(a=='*'||b=='+'||b=='-'||b==')')return 1;
40 return 0;
41 }
42 pll solve(pll a,pll b,char ord){
43 if(ord=='+')return a+b;
44 if(ord=='-')return a-b;
45 if(ord=='*')return a*b;
46 return mp(0,0);
47 }
48 int main(){
49 scanf("%s",str+1);
50 len=strlen(str+1);
51 P=read(),M=read();
52 str[++len]=')';
53 ch.push('(');
54 for(LL i=1;i<=len;++i){
55 // printf("i==%d\n",i);
56 if(str[i]=='x')sta.push(mp(1,0));
57 else if(isnum(str[i])){
58 LL num=str[i]^48;
59 while(isnum(str[i+1]))
60 num=((num<<1)+(num<<3)+(str[++i]^48))%M;
61 sta.push(mp(0,num));
62 }
63 else{
64 while(cmpPrio(ch.top(),str[i])){
65 pll x,y;
66 x=sta.top();
67 sta.pop();
68 y=sta.top();
69 sta.pop();
70 sta.push(solve(y,x,ch.top()));
71 ch.pop();
72 }
73 if(str[i]==')')ch.pop();
74 else ch.push(str[i]);
75 }
76 }
77 pll res=sta.top();
78 for(LL i=0;i<=M;++i)if((res.ft*i+res.sd)%M==P)
79 return !printf("%lld\n",i);
80 return 0;
81 }

[多校联考]SLON!!!的更多相关文章

  1. 三校联考 Day3

    三校联考 Day3 大水题 题目描述:给出一个圆及圆上的若干个点,问两个点间的最远距离. solution 按极角排序,按顺序枚举,显然距离最远的点是单调的,线性时间可解出答案. 大包子的束缚 题目描 ...

  2. 【赛时总结】NOIP2018-三校联考1024

    ◇NOIP三校联考-1024◇ 发现以前的博客写得似乎都很水……基本上都没什么阅读量QwQ 决定改过自新╰( ̄ω ̄o) 就从这篇博客开始吧~ 现场考得无地自容,看到题解才发现一些东西……(我第三题还没 ...

  3. [2019多校联考(Round 6 T3)]脱单计划 (费用流)

    [2019多校联考(Round 6 T3)]脱单计划 (费用流) 题面 你是一家相亲机构的策划总监,在一次相亲活动中,有 n 个小区的若干男士和 n个小区的若干女士报名了这次活动,你需要将这些参与者两 ...

  4. [多校联考2019(Round 5 T1)] [ATCoder3912]Xor Tree(状压dp)

    [多校联考2019(Round 5)] [ATCoder3912]Xor Tree(状压dp) 题面 给出一棵n个点的树,每条边有边权v,每次操作选中两个点,将这两个点之间的路径上的边权全部异或某个值 ...

  5. [多校联考2019(Round 5 T2)]蓝精灵的请求(二分图染色+背包)

    [多校联考2019(Round 5)]蓝精灵的请求(二分图染色+背包) 题面 在山的那边海的那边住着 n 个蓝精灵,这 n 个蓝精灵之间有 m 对好友关系,现在蓝精灵们想要玩一个团队竞技游戏,需要分为 ...

  6. [多校联考2019(Round 5 T3)]青青草原的表彰大会(dp+组合数学)

    [多校联考2019(Round 5)]青青草原的表彰大会(dp+组合数学) 题面 青青草原上有n 只羊,他们聚集在包包大人的家里,举办一年一度的表彰大会,在这次的表彰大会中,包包大人让羊们按自己的贡献 ...

  7. 【五校联考1day2】JZOJ2020年8月12日提高组T2 我想大声告诉你

    [五校联考1day2]JZOJ2020年8月12日提高组T2 我想大声告诉你 题目 Description 因为小Y 是知名的白富美,所以自然也有很多的追求者,这一天这些追求者打算进行一次游戏来踢出一 ...

  8. 【五校联考1day2】JZOJ2020年8月12日提高组T1 对你的爱深不见底

    [五校联考1day2]JZOJ2020年8月12日提高组T1 对你的爱深不见底 题目 Description 出乎意料的是,幸运E 的小R 居然赢了那个游戏.现在欣喜万分的小R 想要写一张明信片给小Y ...

  9. [2017/5/28]FJ四校联考

    来自FallDream的博客,未经允许,请勿转载,谢谢. 话说这一段时间算是过去了,好久好久之后终于又有联考了  没想到这次到我们学校出题,昨天才想起来,临时花一天赶了一套,我出了一个sbFFT,质量 ...

随机推荐

  1. 使用node查询数据库(mysql)时,日期格式不对的问题。

    https://blog.csdn.net/chanlingmai5374/article/details/93190983 1.问题场景 数据库里存了 datetime.但 Node 查询出来是这样 ...

  2. 安卓之滚动视图ScrollView

    (1)垂直方向滚动时,layout_width要设置为match_parent,layout_height要设置为wrap_content (2)水平方向滚动时,layout_width要设置为wra ...

  3. chrome 2行换行省略号 ... text-ellipse

    display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; overflow: hidden; 谷歌内部项目 ...

  4. pycharm连接数据库报错Access denied for user 'root'@'localhost' (using password:YES),以及wampserver 2/3个服务器正在运行 问题

    使用mysql版本为mysql5.7,参考下列 https://blog.csdn.net/qq_32969455/article/details/79051932 https://blog.csdn ...

  5. C语言:去除一个字符串中所有的空格。-函数fun传入形参m,求t=1/2-1/3+1/4.....+1/m的值。-判断形参a指定的矩阵是不是“幻方“。

    //函数fun功能:判断形参a指定的矩阵是不是“幻方“,若是返回1.(”幻方”:每列,每行,对角线,反对角线相加都相等) #include <stdio.h> #define N 3 in ...

  6. Python web在IIS上发布方法和原理

    Python web应用想要发布使用iis发布有两种方式,这篇文章就为大家介绍一下这两种方式的具体实现: 1.配置HttpPlatform程序 HttpPlatform 模块将套接字连接直接传递到独立 ...

  7. Fluent_Python_Part3函数即对象,06-dp-1class-func,一等函数与设计模式

    使用一等函数实现设计模式 中文电子书P278 合理利用作为一等对象的函数,把模式中涉及的某些类的实例替换成简单的函数,从而简化代码. 1. 重构"策略"模式 中文电子书P282 P ...

  8. [SUCTF 2019]Pythonginx

    贴出源码 @app.route('/getUrl', methods=['GET', 'POST']) def getUrl(): url = request.args.get("url&q ...

  9. 《如何写好商业计划书》---创业学习---训练营第三课---HHR---

    一,<开始上课> 1,投资人不愿意约见的原因:创始人没有把项目的投资价值和亮点呈现在商业计划书里. 2,BP的三个常见的错误:不够完整,关键内容没有呈现出来:华而不实:篇幅过长. 3,预热 ...

  10. loadrunner测试sql语句性能

    最初的想法是是想通过录制在SQL Server2008的操作来着的,无奈试了即便都录不到查询的sql语句,网上查资料全是关于SQL 2000的(这部分有经验的欢迎指教). 于是只能通过直接调用load ...