leetcode 2810.故障键盘

思路:模拟

其中题解中有用双端队列做的,大家可以参考一下,这里我就展示一下暴力怎么用。

这里就不多说了,直接看模拟过程就行了,代码中会有注释。

注意:这里在反转的时候,作者用到了一个容器就是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;
    }
};
相关推荐
勤劳的进取家13 小时前
数据链路层基础
网络·学习·算法
南境十里·墨染春水13 小时前
C++笔记 STL——set
开发语言·c++·笔记
dgaf13 小时前
DX12 快速教程(17) —— 立体图标与合并渲染
c语言·c++·3d·图形渲染·d3d12
Advancer-13 小时前
第二次蓝桥杯总结(上)
java·算法·职场和发展·蓝桥杯
ん贤13 小时前
加密算法(对称、非对称、哈希、签名...)
算法·哈希算法
superior tigre14 小时前
78 子集
算法·leetcode·深度优先·回溯
天威?*14 小时前
bitset的数据结构用法
算法·动态规划
hoiii18714 小时前
粒子滤波跟踪系统 - 蒙特卡洛方法实现
算法
weisian15115 小时前
Java并发编程--47-分布式ID生成器:雪花算法(Snowflake)与时钟回拨问题
java·算法·时钟回拨·雪花算法id
itzixiao15 小时前
L1-066 猫是液体(5分)[java][python]
java·开发语言·python·算法