1844-将所有数字用字符替换
 
                给你一个下标从 0 开始的字符串 s ,它的 偶数 下标处为小写英文字母, 奇数 下标处为数字。
定义一个函数 shift(c, x) ,其中 c 是一个字符且 x 是一个数字,函数返回字母表中 c 后面第 x 个字符。
- 比方说,shift('a', 5) = 'f'和shift('x', 0) = 'x'。
对于每个 奇数 下标 i ,你需要将数字 s[i] 用 shift(s[i-1], s[i]) 替换。
请你替换所有数字以后,将字符串 s 返回。题目 保证 __shift(s[i-1], s[i]) 不会超过 'z' 。
示例 1:
**输入:** s = "a1c1e1"
**输出:** "abcdef"
**解释:** 数字被替换结果如下:
- s[1] -> shift('a',1) = 'b'
- s[3] -> shift('c',1) = 'd'
- s[5] -> shift('e',1) = 'f'
示例 2:
**输入:** s = "a1b2c3d4e"
**输出:** "abbdcfdhe"
**解释:** 数字被替换结果如下:
- s[1] -> shift('a',1) = 'b'
- s[3] -> shift('b',2) = 'd'
- s[5] -> shift('c',3) = 'f'
- s[7] -> shift('d',4) = 'h'
提示:
- 1 <= s.length <= 100
- s只包含小写英文字母和数字。
- 对所有 奇数 下标处的 i,满足shift(s[i-1], s[i]) <= 'z'。
方法一:模拟
思路与算法
我们以两个字符为一组对字符串按要求进行修改即可。
对于 C++,我们直接在 s 上进行修改即可。
对于 Python,由于我们无法直接修改字符串,因此需要引入辅助数组 arr,并在辅助数组上进行相应操作,最终转化回字符串。
代码
| 1 | class Solution { | 
| 1 | class Solution: | 
复杂度分析
- 时间复杂度:O(n),其中 n 为字符串的长度。我们对字符串进行了常数次数的遍历操作,单次遍历操作的时间复杂度为 O(n)。 
- 空间复杂度:这里由于 Python 中无法修改字符串,因此不同语言的代码实现有一定区别。对应的空间复杂度也有所区别。 - C++ 代码:O(1),我们直接对原字符串进行修改。 
- Python 代码:O(n),即为辅助数组 arr 的空间开销。 
 
         Comments