LeetCode2109
LeetCode.2109:向字符串中添加空格
一开始我还以为是一道API题,后来发现四五行代码居然TLE了,最后发现果然真的是一道API题。
题目描述
给你一个下标从 0 开始的字符串 s
,以及一个下标从 0 开始的整数数组 spaces
。
数组 spaces
描述原字符串中需要添加空格的下标。每个空格都应该插入到给定索引处的字符值 之前 。
- 例如,
s = "EnjoyYourCoffee"
且spaces = [5, 9]
,那么我们需要在'Y'
和'C'
之前添加空格,这两个字符分别位于下标5
和下标9
。因此,最终得到 $”Enjoy\ \textbf{Y}our\ \text{C}offee”$ 。
请你添加空格,并返回修改后的字符串。
示例
示例1:
1 | 输入:s = "LeetcodeHelpsMeLearn", spaces = [8,13,15] |
示例2:
1 | 输入:s = "icodeinpython", spaces = [1,5,7,9] |
示例3:
1 | 输入:s = "spacing", spaces = [0,1,2,3,4,5,6] |
提示:
1 | 1 <= s.length <= 3 * 105 |
题解
C++中对字符串操作有直接在$i$位置插入的方法$std::string.insert(i,j,”s”)$ 其中$i$代表插入的位置,$j$代表插入字符串的长度,$s$代表插入的字符串。但是这个方法其实也是处理了一次字符串移位(从后往前一个个往后挪动),所以时间复杂度为$O(m*n)$,但是如果为每个字符重新计算其索引的话,时间复杂度即可到达$O(n+m)$。
代码
1 | class Solution { |
复杂度分析
- 时间复杂度:$O(N)$,其中 N 是字符串 s 的长度。
- 空间复杂度:$O(N)$。