【Leetcode】2810. 故障键盘

文章目录

题目

题目链接🔗

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

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

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

示例 1:

输入:s = "string"

输出:"rtsng"

解释:

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

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

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

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

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

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

因此,返回 " r t s n g " "rtsng" "rtsng" 。
示例 2:

输入:s = "poiinter"

输出:"ponter"

解释:

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

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

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

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

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

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

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

输入第 8 8 8 个字符后,屏幕上的文本是: " p o n t e r " "ponter" "ponter" 。

因此,返回 " p o n t e r " "ponter" "ponter" 。
提示:

  • 1 ≤ s . l e n g t h ≤ 100 1 \leq s.length \leq 100 1≤s.length≤100
  • s s s 由小写英文字母组成
  • s [ 0 ] ! = ′ i ′ s[0] != 'i' s[0]!=′i′

思路

这道题目要求模拟故障键盘的输入,其中故障键盘会在输入字符 'i' 时反转已输入的字符串,而其他字符则正常输入。所以我们需要一个变量来追踪当前输入的方向(从左到右或从右到左),以及一个数据结构来存储已输入的字符。

  1. 使用一个 d e q u e deque deque(双端队列)来存储字符,因为我们需要在两端进行插入操作。
  2. 使用一个布尔变量 l e f t 2 r i g h t left2right left2right 来追踪当前输入方向,初始值为 t r u e true true 表示从左到右。
  3. 遍历字符串 s s s,对于每个字符:
  • 如果是字符 ′ i ′ 'i' ′i′,则将 l e f t 2 r i g h t left2right left2right 取反,表示要改变输入方向。
  • 如果当前输入方向是从左到右,则将字符加入到双端队列的末尾。
  • 如果当前输入方向是从右到左,则将字符加入到双端队列的开头。
  1. 根据 l e f t 2 r i g h t left2right left2right 的值来确定最终输出的字符串是正序还是逆序。

代码

c++ 复制代码
class Solution {
public:
    string finalString(string s) {
        deque<char> dq;
        bool left2right = true;  // 从左到右
        for (int i = 0; i < s.length(); ++i) 
        {
            if (s[i] == 'i') left2right = !left2right;  // 反向
            else if (left2right) dq.push_back(s[i]);
            else dq.push_front(s[i]);
        }
        return left2right ? string(dq.begin(), dq.end()) : string(dq.rbegin(), dq.rend());
    }
};

复杂度分析

时间复杂度

O ( n ) O(n) O(n)

空间复杂度

O ( n ) O(n) O(n)

结果

总结

通过维护输入方向和使用双端队列,可以在 O ( n ) O(n) O(n) 的时间和 O ( n ) O(n) O(n) 的空间内完成

相关推荐
且听风吟ayan21 分钟前
leetcode day13 贪心 45+55
leetcode·c#
时光の尘1 小时前
C语言菜鸟入门·关键字·int的用法
c语言·开发语言·数据结构·c++·单片机·链表·c
sjsjs111 小时前
【数据结构-表达式解析】【hard】力扣224. 基本计算器
数据结构·算法·leetcode
C++忠实粉丝1 小时前
计算机网络socket编程(6)_TCP实网络编程现 Command_server
网络·c++·网络协议·tcp/ip·计算机网络·算法
坊钰1 小时前
【Java 数据结构】时间和空间复杂度
java·开发语言·数据结构·学习·算法
武昌库里写JAVA2 小时前
一文读懂Redis6的--bigkeys选项源码以及redis-bigkey-online项目介绍
c语言·开发语言·数据结构·算法·二维数组
禊月初三2 小时前
LeetCode 4.寻找两个中序数组的中位数
c++·算法·leetcode
学习使我飞升2 小时前
spf算法、三类LSA、区间防环路机制/规则、虚连接
服务器·网络·算法·智能路由器
戊子仲秋2 小时前
【LeetCode】每日一题 2024_11_23 矩阵中的蛇(哈希、计数)
leetcode·矩阵·哈希算法
庞传奇2 小时前
【LC】560. 和为 K 的子数组
java·算法·leetcode