2810. 故障键盘(javascript)

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

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

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

示例 1:

javascript 复制代码
输入:s = "string"
输出:"rtsng"
解释:
输入第 1 个字符后,屏幕上的文本是:"s" 。
输入第 2 个字符后,屏幕上的文本是:"st" 。
输入第 3 个字符后,屏幕上的文本是:"str" 。
因为第 4 个字符是 'i' ,屏幕上的文本被反转,变成 "rts" 。
输入第 5 个字符后,屏幕上的文本是:"rtsn" 。
输入第 6 个字符后,屏幕上的文本是: "rtsng" 。
因此,返回 "rtsng" 。

示例 2:

javascript 复制代码
输入:s = "poiinter"
输出:"ponter"
解释:
输入第 1 个字符后,屏幕上的文本是:"p" 。
输入第 2 个字符后,屏幕上的文本是:"po" 。
因为第 3 个字符是 'i' ,屏幕上的文本被反转,变成 "op" 。
因为第 4 个字符是 'i' ,屏幕上的文本被反转,变成 "po" 。
输入第 5 个字符后,屏幕上的文本是:"pon" 。
输入第 6 个字符后,屏幕上的文本是:"pont" 。
输入第 7 个字符后,屏幕上的文本是:"ponte" 。
输入第 8 个字符后,屏幕上的文本是:"ponter" 。
因此,返回 "ponter" 。
javascript 复制代码
/**
 * @param {string} s
 * @return {string}
 */
var finalString = function (s) {
    let list = []
    for (let i = 0; i < s.length; i++) {
        if (s[i] == 'i') {
            list.reverse()
        } else {
            list.push(s[i])
        }
    }
    return list.join('')
};
javascript 复制代码
/**
 * @param {string} s
 * @return {string}
 */
var finalString = function (s) {
    //存储数据
    let list = []
    //对s进行遍历,遇到非i的数据,将数据加到list里面,遇到字符串i,反转之前的数组
    for (let i = 0; i < s.length; i++) {
        if (s[i] == 'i') {
            list.reverse()
        } else {
            list.push(s[i])
        }
    }
    //将最后所得的数组转成字符串
    return list.join('')
};

leetcode:https://leetcode.cn/problems/faulty-keyboard/description/

相关推荐
seasonsyy15 小时前
在虚拟机中安装操作系统需要U盘吗?
windows·操作系统·vmware·虚拟机
jqq66616 小时前
解析ElementPlus打包源码(三、打包类型)
前端·javascript·vue.js
陳陈陳16 小时前
React 性能优化双子星:useMemo 与 useCallback 的正确打开方式
前端·javascript·react.js
持续前行16 小时前
JavaScript 数组中删除偶数下标值的多种方法
前端·javascript·vue.js
Dr_哈哈16 小时前
ESM vs CJS 模块化差异对比
javascript·node.js
Java编程爱好者16 小时前
SpringBoot实现隐式参数注入
javascript
baozj16 小时前
给 Ant Design Vue 装上"涡轮增压":虚拟列表封装实践
前端·javascript·vue.js
追逐梦想之路_随笔16 小时前
JavaScript Es9、Es10、Es11、Es12、Es13、Es14、Es15新特性总结
javascript·es9至es15新特性
黛色正浓17 小时前
leetCode-热题100-二叉树合集(JavaScript)
javascript·算法·leetcode