LeetCode 2810.故障键盘

你的笔记本键盘存在故障,每当你在上面输入字符 'i' 时,它会反转你所写的字符串。而输入其他字符则可以正常工作。

给你一个下标从 0 开始的字符串 s ,请你用故障键盘依次输入每个字符。

返回最终笔记本屏幕上输出的字符串。

示例 1:

输入:s = "string"

输出:"rtsng"

解释:

输入第 1 个字符后,屏幕上的文本是:"s" 。

输入第 2 个字符后,屏幕上的文本是:"st" 。

输入第 3 个字符后,屏幕上的文本是:"str" 。

因为第 4 个字符是 'i' ,屏幕上的文本被反转,变成 "rts" 。

输入第 5 个字符后,屏幕上的文本是:"rtsn" 。

输入第 6 个字符后,屏幕上的文本是: "rtsng" 。

因此,返回 "rtsng" 。

示例 2:

输入:s = "poiinter"

输出:"ponter"

解释:

输入第 1 个字符后,屏幕上的文本是:"p" 。

输入第 2 个字符后,屏幕上的文本是:"po" 。

因为第 3 个字符是 'i' ,屏幕上的文本被反转,变成 "op" 。

因为第 4 个字符是 'i' ,屏幕上的文本被反转,变成 "po" 。

输入第 5 个字符后,屏幕上的文本是:"pon" 。

输入第 6 个字符后,屏幕上的文本是:"pont" 。

输入第 7 个字符后,屏幕上的文本是:"ponte" 。

输入第 8 个字符后,屏幕上的文本是:"ponter" 。

因此,返回 "ponter" 。

提示:

1 <= s.length <= 100

s 由小写英文字母组成

s0 != 'i'

法一:遍历一遍s,每遇到i就翻转前面包括i在内的所有字符,因为有没有i都不影响除i以外的字符的相对顺序,最后再删掉i即可:

cpp 复制代码
class Solution {
public:
    string finalString(string s) {
        for (int i = 0; i < s.size(); ++i)
        {
            if (s[i] == 'i')
            {
                reverse(s, 0, i);
            }
        }

        size_t pos = string::npos;
        while ((pos = s.find('i')) != string::npos)
        {
            s.erase(pos, 1);
        }

        return s;
    }

private:
    void reverse(string &s, int begin, int end)
    {
        while (begin < end)
        {
            swap(s[begin++], s[end--]);
        }
    }
};

如果s的长度为n,则此算法时间复杂度为O(n 2 ^2 2),空间复杂度为O(1)。

法二:每次出现i可看作往相反的方向将字符添加到结果字符串,如string,遍历到i前,正向存入结果str,遇到i后,反向存入结果gnstr,如果根据方向翻转结果为rtsng:

cpp 复制代码
class Solution {
public:
    string finalString(string s) {
        // 由于要双向存结果,因此选用双向队列
        deque<char> dq;
        bool tail = true;
        for (char c : s)
        {
            if (c == 'i')
            {
                tail = !tail;
            }
            else if (tail)
            {
                dq.push_back(c);
            }
            else
            {
                dq.push_front(c);
            }
        }

        return tail ? string(dq.begin(), dq.end()) : string(dq.rbegin(), dq.rend());
    }
};

如果s的长度为n,则此算法时间复杂度为O(n),空间复杂度为O(n)。

相关推荐
MicroTech202515 分钟前
量子隐形传态路线的瓶颈与突破,微算法科技(MLGO)以技术创新助力量子通信长距离组网
科技·算法·量子计算
洛水水16 分钟前
【力扣100题】89.下一个排列
数据结构·算法·leetcode
洛水水17 分钟前
【力扣100题】90.寻找重复数
算法·leetcode·职场和发展
鱼子星_22 分钟前
【数据结构】排序的拓展——快速排序的生态多样性与归并排序沾染文件操作
c语言·数据结构·算法
alphaTao22 分钟前
LeetCode 每日一题 2026/6/8-2026/6/14
算法·leetcode
KaMeidebaby27 分钟前
卡梅德生物技术快报|噬菌体展示文库构建全流程解析 | 大豆球蛋白纳米抗体筛选实践
人工智能·python·tcp/ip·算法·机器学习
CC数学建模35 分钟前
2026年第十六届APMCM 亚太地区大学生数学建模竞赛(中文赛项)赛题B题:高性能芯片热管理系统的优化问题完整思路、代码、模型、文章,全网首发高质量分享!
python·算法·数学建模
爱睡懒觉的焦糖玛奇朵44 分钟前
【视觉检测之人员奔跑检测算法开发思路】
人工智能·python·深度学习·算法·yolo·视觉检测
05候补工程师1 小时前
【408考研复习】数据结构核心笔记:字符串模式匹配与内部排序算法全解析
数据结构·经验分享·笔记·考研·算法·排序算法
阿文的代码库1 小时前
浅谈:无向图的欧拉回路
算法