首页 > 其他 > 详细

P4868 天天和不可描述

时间:2017-10-01 13:01:31      阅读:333      评论:0      收藏:0      [点我收藏+]

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 天天和不可描述

原文:http://www.cnblogs.com/CLGYPYJ/p/7616999.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!