【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 1s.length100
  • 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 的值来确定最终输出的字符串是正序还是逆序。

代码

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) 的空间内完成

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/506665.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

.sdf和.msp文件读取

前言 .sdf和.msp文件都可以用来存储分子信息&#xff0c;.sdf文件可以用rdkit读取&#xff0c;.msp文件就只能当成文本文档读取了。 读取 rdkit安装 pip install rdkit .sdf读取 from rdkit import Chemsuppl_h Chem.SDMolSupplier(../data/HMDB/f_hmdb.sdf) # 得到一个迭…

【字节跳动笔试题汇总】 2024-03-31-字节跳动春招笔试题-三语言题解(CPP/Python/Java)

&#x1f36d; 大家好这里是KK爱Coding &#xff0c;一枚热爱算法的程序员 ✨ 本系列打算持续跟新字节跳动近期的春秋招笔试题汇总&#xff5e; &#x1f4bb; ACM银牌&#x1f948;| 多次AK大厂笔试 &#xff5c; 编程一对一辅导 &#x1f44f; 感谢大家的订阅➕ 和 喜欢&…

基于Python的口罩佩戴识别的设计与实现(UI界面+MySQL数据库+YOLOv5+训练数据集+开题报告+中期检查+论文)

本文旨在基于Python开发一种口罩佩戴识别系统&#xff0c;通过深度学习技术实现对口罩佩戴情况的准确检测。采用了YOLOv5系列目标检测算法作为基础模型&#xff0c;并结合迁移学习进行训练和优化。同时&#xff0c;为了提供更好的用户体验&#xff0c;本系统还设计了用户登录注…

“315晚会”中的“网络水军”是什么?

水军一词&#xff0c;源自网络用语&#xff0c;通常指的是一群在网络上被雇佣来进行特定活动的人群。他们的主要任务通常是在各种社交媒体平台、论坛或者评论区发表大量的帖子、评论或者回复&#xff0c;以此来达到某种特定的目的。这些目的可能包括提升某个产品、服务或者个人…

【机器学习300问】58、什么是词袋模型和N-gram模型?

词袋模型&#xff08;Bag of Words, BoW&#xff09;和N-gram模型主要用于早期的自然语言处理任务&#xff0c;上文中我介绍了机器是如何读懂文本的四个阶段&#xff0c;这篇文章带大家来看看在不同阶段中会用到的两个模型——词袋模型和N-gram模型。如果没有读过我之前的文章&…

纯小白蓝桥杯备赛笔记--DAY9(搜索)

文章目录 三道例题学会DFS剪枝什么是剪枝数字王国之军训排队--2942特殊的三角形--3008特殊的多边形--3075 DFS基础回溯简介回溯法模版例题N皇后--1508小朋友崇拜圈--182全球变暖--178 记忆化搜索简介斐波那契数列混境之地5-3820地宫取宝-216 三道例题学会DFS剪枝 什么是剪枝 …

云计算迎变局:阿里云、腾讯云“各有千秋”

毋庸置疑&#xff0c;无论在什么时候什么行业&#xff0c;低价策略都是一柄利器。比如&#xff0c;在电商行业&#xff0c;除了拼多多将低价策略贯彻到底之外&#xff0c;淘宝、京东也将性价比作为发力重点&#xff0c;并通过补贴、秒杀等方式&#xff0c;再度强调自身的“价格…

Pygame基础8-碰撞

Collisions 在Pygame中&#xff0c;我们使用矩形来移动物体&#xff0c;并且用矩形检测碰撞。 colliderect检测两个矩形是否碰撞&#xff0c;但是没法确定碰撞的方向。 Rect1.colliderect(Rect2) # collision -> return Ture # else -> return Falsecollidepoint可以…

数据结构——遍历二叉树和线索二叉树,树和森林

目录 1.遍历的算法实现 1.先序遍历 代码示例&#xff1a; 2.中序遍历 代码示例&#xff1a; 3.后序遍历 代码示例&#xff1a; 4.遍历算法的分析 2.遍历二叉树的非递归算法 1.中序遍历非递归算法 代码示例&#xff1a; 3.二叉树的层次遍历 代码示例&#xff1a; 4.二…

C#/.NET/.NET Core优秀项目和框架2024年3月简报

前言 公众号每月定期推广和分享的C#/.NET/.NET Core优秀项目和框架&#xff08;每周至少会推荐两个优秀的项目和框架当然节假日除外&#xff09;&#xff0c;公众号推文中有项目和框架的介绍、功能特点、使用方式以及部分功能截图等&#xff08;打不开或者打开GitHub很慢的同学…

BUUCTF [安洵杯 2019]吹着贝斯扫二维码 1

BUUCTF:https://buuoj.cn/challenges 题目描述&#xff1a; 得到的 flag 请包上 flag{} 提交。 密文&#xff1a; 下载附件解压&#xff0c;得到很多没有后缀的文件和一个ZIP压缩包。 解题思路&#xff1a; 1、首先&#xff0c;查看ZIP压缩包&#xff0c;发现有密码&#xf…

GreatSQL 优化技巧:将 MINUS 改写为标量子查询

GreatSQL 优化技巧&#xff1a;将 MINUS 改写为标量子查询 前言 minus 指令运用在两个 SQL 语句上&#xff0c;取两个语句查询结果集的差集。它先找出第一个 SQL 所产生的结果&#xff0c;然后看这些结果有没有在第二个 SQL 的结果中&#xff0c;如果在&#xff0c;那这些数据…

2024年山东临沂教育人才引进报名流程

2024年山东临沂教育人才引进报名流程

表单全选反选(前端)

1.Html和JavaScript <table><tr><th class"allCheck"><input type"checkbox" name"" id"checkAll"> <span class"all">全选</span></th><th>商品</th><th>商…

Hive函数笔试题(简单)

第1题 有如下的用户访问数据 userId visitDate visitCount u01 2017/1/21 5 u02 2017/1/23 6 u03 2017/1/22 8 u04 2017/1/20 3 u01 2017/1/23 6 u01 2017/2/21 8 u02 2017/1/23 6 u01 2017/2/22 4 要求使用SQL统计出每个用户的累积访问次数&…

Qt中继承QCheckBox的类结合QTableWidget实现多选并且每个多选的id都不一样

1.相关描述 继承QCheckBox的类MyCheckBox&#xff0c;利用QTableWidget的setCellWidget方式添加MyCheckBox类的对象 2.相关页面 3.相关代码 mycheckbox.h #ifndef MYCHECKBOX_H #define MYCHECKBOX_H#include <QCheckBox> #include <QObject>class MyCheckBox : pu…

DSSS-UQPSK学习笔记

文章目录 非平衡四相键控-直接序列扩频&#xff08;UQPSK-DSSS&#xff09;信号因其能同时传输两路不同功率、不同速率信号的特点&#xff0c;在需要图象和数据综合业务传输的领域得到了广泛应用。 系统信号的调制方式为非平衡四相键控&#xff08;Unbalanced Quadrature Phase…

SpringBoot 整合Redis第1篇

SpringBoot是一个开发框架&#xff0c;Redis是一个高性能的键值存储数据库&#xff0c; 常用于缓存、会话管理、消息队列等应用场景。 定义 Redis是什么&#xff1f; 它是一个存储层级&#xff0c; 在实际项目中&#xff0c;位于关系数据库之上&#xff0c; 类似Android分为5…

vue3封装Element导航菜单

1. 导航外层布局 AsideView.vue <template><el-menu:default-active"defaultActive"class"my-menu":collapse"isCollapse":collapse-transition"false"open"handleOpen"close"handleClose"><menu…

【机器学习入门】拥抱人工智能,从机器学习开始

拥抱人工智能&#xff0c;从机器学习开始 目录&#xff1a; 1. 机器学习&#xff1a;一种实现人工智能的方法2. 机器学习算法&#xff1a;是使计算机具有智能的关键3. Anaconda&#xff1a;初学Python、入门机器学习的首选4. 总结 转载链接&#xff1a;文章-阿里云开发者社区…