跳至主要內容

1844. 将所有数字用字符替换

ITCharge大约 2 分钟

1844. 将所有数字用字符替换open in new window

  • 标签:字符串
  • 难度:简单

题目链接

题目大意

描述:给定一个下标从 00 开始的字符串 ss。字符串 ss 的偶数下标处为小写英文字母,奇数下标处为数字。

定义一个函数 shift(c, x),其中 cc 是一个字符且 xx 是一个数字,函数返回字母表中 cc 后边第 xx 个字符。

  • 比如,shift('a', 5) = 'f'shift('x', 0) = 'x'

对于每个奇数下标 ii,我们需要将数字 s[i]s[i]shift(s[i - 1], s[i]) 替换。

要求:替换字符串 ss 中所有数字以后,将字符串 ss 返回。

说明

  • 题目保证 shift(s[i - 1], s[i]) 不会超过 'z'
  • 1s.length1001 \le s.length \le 100
  • ss 只包含小写英文字母和数字。
  • 对所有奇数下标处的 ii,满足 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:模拟

  1. 先定义一个 shift(ch, x) 用于替换 s[i]
  2. 将字符串转为字符串列表,定义为 resres
  3. 以两个字符为一组遍历字符串,对 res[i]res[i] 进行修改。
  4. 将字符串列表连接起来,作为答案返回。

思路 1:代码

class Solution:
    def replaceDigits(self, s: str) -> str:
        def shift(ch, x):
            return chr(ord(ch) + x) 
        
        res = list(s)
        for i in range(1, len(s), 2):
            res[i] = shift(res[i - 1], int(res[i]))
        
        return "".join(res)

思路 1:复杂度分析

  • 时间复杂度O(n)O(n)
  • 空间复杂度O(n)O(n)