当前位置: 首页 > news >正文

做兼职最好的网站网站移动端优化工具

做兼职最好的网站,网站移动端优化工具,怎么做网站推广线下,对象储存做网站【LetMeFly】2810.故障键盘:双端队列模拟 力扣题目链接:https://leetcode.cn/problems/faulty-keyboard/ 你的笔记本键盘存在故障,每当你在上面输入字符 i 时,它会反转你所写的字符串。而输入其他字符则可以正常工作。 给你一个…

【LetMeFly】2810.故障键盘:双端队列模拟

力扣题目链接:https://leetcode.cn/problems/faulty-keyboard/

你的笔记本键盘存在故障,每当你在上面输入字符 '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 由小写英文字母组成
  • s[0] != 'i'

解题方法:双端队列模拟

使用一个双端队列来存放要输出的字符们,默认将字符添加到双端队列的右边(后面)。

使用一个布尔类型的变量push_front来记录当前字符是否应该添加到双端队列的右边。

遍历字符串:

  • 如果当前字符为i,则说明需要“翻转字符串”。我们不需要真正翻转字符串,只需要标记一下说“原来字符串的头,现在你变成尾了”(翻转变量push_front的值)。
  • 否则,依据变量push_front的值将字符添加到字符串的头或尾。

最终依据变量push_front的值从头到尾或从尾到头将队列中的字符拼接成字符串。

时空复杂度分析

  • 时间复杂度 O ( l e n ( s ) ) O(len(s)) O(len(s))
  • 空间复杂度 O ( l e n ( s ) ) O(len(s)) O(len(s))

虽然这种方法时间复杂度为 O ( n ) O(n) O(n),但是题目的数据返回是 1 0 2 10^2 102级别,因此效果可能不如直接的模拟。

AC代码

C++
class Solution {
public:string finalString(string s) {deque<char> q;bool push_front = false;for (char c : s) {if (c == 'i') {push_front = !push_front;continue;}if (push_front) {q.push_front(c);}else {q.push_back(c);}}return push_front ? string{q.rbegin(), q.rend()} : string{q.begin(), q.end()};}
};
Python
# from collections import dequeclass Solution:def finalString(self, s: str) -> str:q = deque()appendleft = Falsefor c in s:if c == 'i':appendleft = not appendleftcontinueif appendleft:q.appendleft(c)else:q.append(c)return ''.join(q)[::-1] if appendleft else ''.join(q)

愚人节快乐!

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~
Tisfy:https://letmefly.blog.csdn.net/article/details/137242651

http://www.shuangfujiaoyu.com/news/50705.html

相关文章:

  • 家居设计网站推荐百度账号登录不了
  • 网站报301错误网页设计素材
  • 房产网站怎么做400电话常熟网络推广
  • 网站源码绑定域名处理谷歌浏览器下载安装2021最新版
  • 世界500强企业关于优秀员工的12条核心标准网络seo哈尔滨
  • 呼和浩特整站优化站长之家seo信息
  • 四川中成煤炭建设集团网站新闻源软文推广平台
  • wordpress手机版加搜索框一点优化
  • 名匠装饰seo域名综合查询
  • 潍坊互联网推广福州seo结算
  • 浮梁网站推广双11销售数据
  • 做网站价格差异很大百度推广的方式
  • 网站建设的原则和目标建站为应用技术
  • 网站日志查询系统最新舆情信息网
  • 做游戏视频网站有哪些steam交易链接可以随便给别人吗
  • 做网站推广如何北京网站优化方式
  • 代做原创毕业设计网站百度广告
  • 建设自己的网站怎么做品牌策略有哪些
  • 无锡网站制作公司排名黄冈地区免费网站推广平台
  • 网站开发绩效指标沧州网站seo
  • 顺德品牌网站建设信息免费游戏推广平台
  • dreamweaver 做网站沧州网站优化公司
  • 政府网站开发文档常德网站seo
  • 专业做装修的网站农产品网络营销策划书
  • mysql做网站文件关键词搜索工具
  • wap网站如何做专业网站推广优化
  • 想做棋牌网站怎么做推广普通话手抄报模板
  • 杭州租车网站建设百度seo视频教程
  • 上海要做网站网站搜索排名优化价格
  • 网站pv访问量统计怎么做谷歌关键词排名优化