此处采用的是链表的思想,具体实现过程任然需要注意,知识是死的,而自己的思想是活的,加油,自己
<pre name="code" class="cpp">#include <iostream> #include <cstring> #include <cstdio> using namespace std; #define maxn 100005 int cur, last, next[maxn]; char s[maxn]; int main() { while(~scanf("%s",s+1)) { int n = strlen(s+1); last=cur=0; next[0]=0; for(int i=1; i<=n; i++) { char ch=s[i]; if(ch=='[') cur=0; else if(ch==']') cur=last; else { next[i]=next[cur];///光标原来所指向的位置需要进行保留 next[cur]=i;///光标此时指向的下一个数自然就是s[i],这里表示为在字符串中其位置 if(cur == last) last=i; cur=i; } } for(int i=next[0]; i!=0; i=next[i]) cout<<s[i]; cout<<endl; } return 0; }
时间: 2024-10-25 16:55:24