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/

相关推荐
一枚前端小能手24 分钟前
🔥 滚动监听写到手抽筋?IntersectionObserver让你躺平实现懒加载
前端·javascript
遂心_26 分钟前
React中的onChange事件:从原理到实践的全方位解析
前端·javascript·react.js
GHOME28 分钟前
原型链的原貌
前端·javascript·面试
luckyCover30 分钟前
带你一起攻克js之原型到原型链~
前端·javascript
麦当_32 分钟前
SwipeMultiContainer 滑动切换容器算法指南
前端·javascript·算法
用户315063273048735 分钟前
使用 vue-virtual-scroller 实现高性能传输列表功能总结
javascript·vue.js
前端小巷子1 小时前
JS打造“九宫格抽奖”
前端·javascript·面试
Ares-Wang2 小时前
Vue3》》eslint Prettier husky
开发语言·javascript·ecmascript
EveryPossible2 小时前
静态箭头连线
开发语言·javascript·ecmascript
伍哥的传说2 小时前
QRCode React 完全指南:现代化二维码生成解决方案
前端·javascript·react.js·qrcode.react·react二维码生成·qrcodesvg·qrcodecanvas