2296.设计一个文本编辑器:对顶栈-主要是要细心下标问题(ASCII字符通俗语言描述)
【LetMeFly】2296.设计一个文本编辑器:对顶栈-主要是要细心下标问题(ASCII字符通俗语言描述)
力扣题目链接:https://leetcode.cn/problems/design-a-text-editor/
请你设计一个带光标的文本编辑器,它可以实现以下功能:
- 添加:在光标所在处添加文本。
 - 删除:在光标所在处删除文本(模拟键盘的删除键)。
 - 移动:将光标往左或者往右移动。
 
当删除文本时,只有光标左边的字符会被删除。光标会留在文本内,也就是说任意时候 0 <= cursor.position <= currentText.length 都成立。
请你实现 TextEditor 类:
TextEditor()用空文本初始化对象。void addText(string text)将text添加到光标所在位置。添加完后光标在text的右边。int deleteText(int k)删除光标左边k个字符。返回实际删除的字符数目。string cursorLeft(int k)将光标向左移动k次。返回移动后光标左边min(10, len)个字符,其中len是光标左边的字符数目。string cursorRight(int k)将光标向右移动k次。返回移动后光标左边min(10, len)个字符,其中len是光标左边的字符数目。
示例 1:
输入:
["TextEditor", "addText", "deleteText", "addText", "cursorRight", "cursorLeft", "deleteText", "cursorLeft", "cursorRight"]
[[], ["leetcode"], [4], ["practice"], [3], [8], [10], [2], [6]]
输出:
[null, null, 4, null, "etpractice", "leet", 4, "", "practi"]
解释:
TextEditor textEditor = new TextEditor(); // 当前 text 为 "|" 。('|' 字符表示光标)
textEditor.addText("leetcode"); // 当前文本为 "leetcode|" 。
textEditor.deleteText(4); // 返回 4
                          // 当前文本为 "leet|" 。
                          // 删除了 4 个字符。
textEditor.addText("practice"); // 当前文本为 "leetpractice|" 。
textEditor.cursorRight(3); // 返回 "etpractice"
                           // 当前文本为 "leetpractice|". 
                           // 光标无法移动到文本以外,所以无法移动。
                           // "etpractice" 是光标左边的 10 个字符。
textEditor.cursorLeft(8); // 返回 "leet"
                          // 当前文本为 "leet|practice" 。
                          // "leet" 是光标左边的 min(10, 4) = 4 个字符。
textEditor.deleteText(10); // 返回 4
                           // 当前文本为 "|practice" 。
                           // 只有 4 个字符被删除了。
textEditor.cursorLeft(2); // 返回 ""
                          // 当前文本为 "|practice" 。
                          // 光标无法移动到文本以外,所以无法移动。
                          // "" 是光标左边的 min(10, 0) = 0 个字符。
textEditor.cursorRight(6); // 返回 "practi"
                           // 当前文本为 "practi|ce" 。
                           // "practi" 是光标左边的 min(10, 6) = 6 个字符。
提示:
1 <= text.length, k <= 40text只含有小写英文字母。- 调用 
addText,deleteText,cursorLeft和cursorRight的 总 次数不超过2 * 104次。 
进阶:你能设计并实现一个每次调用时间复杂度为 O(k) 的解决方案吗?
解题方法:左右两个栈
栈长这样:
1  |  | 
使用左右两个栈,右边的栈画成方向向左:
1  |  | 
那么鼠标指向的位置不就是两栈的中间么?
添加:
直接将新字符串依次入栈左栈
删除:
直接左栈出栈
左移:
直接左栈出栈并加入到右栈
右移:
直接右栈出栈并加入到左栈
这题考的就是是否细心(下标是否挣钱以及是否越界问题)。
- 时间复杂度:初始化$O(1)$,添加$O(len(text))$,左右移$O(k)$
 - 空间复杂度$O(N\log N)$
 
AC代码
C++
1  |  | 
Python
1  |  | 
Go
1  |  | 
同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~
千篇源码题解已开源
2296.设计一个文本编辑器:对顶栈-主要是要细心下标问题(ASCII字符通俗语言描述)
      https://blog.letmefly.xyz/2025/02/27/LeetCode 2296.设计一个文本编辑器/