Problem
You are given a string s of lowercase English letters and an integer array shifts of the same length.
Call the shift() of a letter, the next letter in the alphabet, (wrapping around so that 'z' becomes 'a').
- For example,
shift('a') = 'b',shift('t') = 'u', andshift('z') = 'a'.
Now for each shifts[i] = x, we want to shift the first i + 1 letters of s, x times.
Return the final string after all such shifts to s are applied.
https://leetcode.com/problems/shifting-letters/
Example 1:
Input:
s = "abc", shifts = [3,5,9]
Output:"rpl"
Explanation: We start with"abc".
After shifting the first 1 letters of s by 3, we have"dbc".
After shifting the first 2 letters of s by 5, we have"igc".
After shifting the first 3 letters of s by 9, we have"rpl", the answer.
Example 2:
Input:
s = "aaa", shifts = [1,2,3]
Output:"gfd"
Constraints:
1 <= s.length <= 10⁵sconsists of lowercase English letters.shifts.length == s.length0 <= shifts[i] <= 10⁹
Test Cases
1 | class Solution: |
1 | import pytest |
Thoughts
第 i 个字符一共需要 shift Σshifts[:i+1] 次。先逆序遍历一遍 shifts,逐个向前累加即可。
Code
1 | class Solution: |