-
题目考点:STL、栈(或队列),另外注意多组输入
-
题目大意:给出一系列泡泡,两个小泡泡在一起会变成大泡泡,两个大泡泡在一起会爆炸;求这些泡泡的最终状态。
-
题目分析: 依次从前往后遍历压入栈即可(入栈时将当前泡泡与栈顶泡泡相比较,两小泡泡变成大泡泡,两大泡泡爆炸),唯一注意点就是两个小泡泡变成大泡泡后,如果前面一个依然是大泡泡,把栈顶弹出即可。
#include<iostream>
#include<cstring>
#include<algorithm>
#include<stack>
#include<queue>
using namespace std;
const int N = 100010;
int n, m, k, t;
stack<char> r;
string s, ans;
int main()
{
while(cin >> s)
{
for(int i = 0; i < s.size(); i++)
{
char ch = s[i];
if(r.empty()) r.push(ch);
else if(r.top() != ch) r.push(ch);
else
{
r.pop();
if(ch == 'o' && r.empty()) r.push('O'); // 栈空,两个小泡泡变成了大泡泡
else if(ch == 'o' && r.top() == 'O') r.pop();// 栈顶为大泡泡,弹出
}
}
ans = ""; // 处理栈的弹出顺序,这里用queue更方便
while(r.size())
{
ans += r.top();
r.pop();
}
for(int i = ans.size() - 1; i >= 0; i--)
cout << ans[i] ;
cout << '\n';
}
return 0;
}