P4868 天天和不可描述

Posted wang者归来

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了P4868 天天和不可描述相关的知识,希望对你有一定的参考价值。

http://www.tyvj.cn/p/4868

思路:

  本想用站做的,但发现要用很多站同时做,还要来回倒。

  我怕超时,所以换了种做法。

  因为每遇到一次括号都要把输出方向改变,而括号是成对存在的,所以不用担心会走错(放心模拟就行)。

  还有就是,遇到括号是要进行转跳的,所以预处理出,对应括号的位置即可。

  然后模拟着走就ok。

 

#include<iostream>
#include<queue>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<vector>
using namespace std;
#define N 500009
char s[N];
int len;
int cnt,l[N],last[N],x,dir;
int main()
{
    cin>>(s+1);
    len=strlen(s+1);
    for(int i=1;i<=len;i++)
    {
        if(s[i]==\'(\')
            l[++cnt]=i;
        else
        if(s[i]==\')\')
        {
            last[i]=l[cnt];//
            last[l[cnt--]]=i; //
        }
    }
    dir=1;x=1;
    while(x>=1&&x<=len)
    {
        if(last[x])
        {
            x=last[x];
            dir*=-1;
        }
        else
            printf("%c",s[x]);
        x+=dir;
    }
    return 0;
} 

 

以上是关于P4868 天天和不可描述的主要内容,如果未能解决你的问题,请参考以下文章

#587. 天天和不可描述

差分+树状数组p4868Preprefix sum

noip模拟赛 天天和不可描述

ListView 不可点击,行中的所有小部件都是 TextView

为啥我在这个 python 片段中得到 float 是不可迭代的? [复制]

NOIP模拟赛16