思路:模拟
其中题解中有用双端队列做的,大家可以参考一下,这里我就展示一下暴力怎么用。
这里就不多说了,直接看模拟过程就行了,代码中会有注释。
注意:这里在反转的时候,作者用到了一个容器就是list容器,之所以用,是因为里面含有一个函数叫做reverse,就是反转的意思,在这里很方便。
class Solution {
public:
string finalString(string s) {
list<char>L;
int n=s.size();
string buf;
int index1=0;
int index2=0;
for(int i=0;i<n;i++){
if(s[i]=='i'){
index2=i;
if(index1+1==index2&&index1!=0)
L.reverse();
else{
for(int j=index1;j<index2;j++){
if(s[j]!='i')
L.push_back(s[j]);
}
L.reverse();
}
index1=index2;
}
}
for(auto it:L)
buf+=it;
if(index2!=0)
buf+=s.substr(index2+1);
else
buf+=s.substr(index2);
return buf;
}
};