848. 字母移位

Posted mikemeng

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了848. 字母移位相关的知识,希望对你有一定的参考价值。

有一个由小写字母组成的字符串 S,和一个整数数组 shifts。

我们将字母表中的下一个字母称为原字母的 移位(由于字母表是环绕的, z 将会变成 a)。

例如·,shift(a) = b, shift(t) = u,, 以及 shift(z) = a。

对于每个 shifts[i] = x , 我们会将 S 中的前 i+1 个字母移位 x 次。

返回将所有这些移位都应用到 S 后最终得到的字符串。

示例:

输入:S = "abc", shifts = [3,5,9]
输出:"rpl"
解释: 
我们以 "abc" 开始。
将 S 中的第 1 个字母移位 3 次后,我们得到 "dbc"。
再将 S 中的前 2 个字母移位 5 次后,我们得到 "igc"。
最后将 S 中的这 3 个字母移位 9 次后,我们得到答案 "rpl"。
提示:

1 <= S.length = shifts.length <= 20000
0 <= shifts[i] <= 10 ^ 9

解题:

class Solution {
public:
    string shiftingLetters(string S, vector<int>& shifts) {
        int n = shifts.size();
        vector<int> sum;
        int cnt = 0;
        
        for(int i = n-1; i>= 0; --i){
            cnt = (cnt + (shifts[i]%26))%26;
            sum.push_back(cnt);
        }
        
        reverse(sum.begin(),sum.end());
        
        for(int i = 0;i < n; ++i){
            //cout<<sum[i]<<endl;
            S[i] = (S[i] + sum[i] - a)%26 + a;
        }
        
        
        return S;
    }
};

 

有一个由小写字母组成的字符串 S,和一个整数数组 shifts

我们将字母表中的下一个字母称为原字母的 移位(由于字母表是环绕的, ‘z‘ 将会变成 ‘a‘)。

例如·,shift(‘a‘) = ‘b‘, shift(‘t‘) = ‘u‘,, 以及 shift(‘z‘) = ‘a‘

对于每个 shifts[i] = x , 我们会将 S 中的前 i+1 个字母移位 x 次。

返回将所有这些移位都应用到 S 后最终得到的字符串。

示例:

输入:S = "abc", shifts = [3,5,9]
输出:"rpl"
解释: 
我们以 "abc" 开始。
将 S 中的第 1 个字母移位 3 次后,我们得到 "dbc"。
再将 S 中的前 2 个字母移位 5 次后,我们得到 "igc"。
最后将 S 中的这 3 个字母移位 9 次后,我们得到答案 "rpl"。

提示:

  1. 1 <= S.length = shifts.length <= 20000
  2. 0 <= shifts[i] <= 10 ^ 9

以上是关于848. 字母移位的主要内容,如果未能解决你的问题,请参考以下文章

js实现密码加密(1.只对字母移位16位加密2.base64加密)

C语言编程: 文件移位加密与解密。

C中Vigenere的密码移位问题

Python-移位密码仿射变换解密

凯撒密码

2021-12-24:划分字母区间。 字符串 S 由小写字母组成。我们要把这个字符串划分为尽可能多的片段,同一字母最多出现在一个片段中。返回一个表示每个字符串片段的长度的列表。 力扣763。某大厂面试