题目
你有一个炸弹需要拆除,时间紧迫!你的情报员会给你一个长度为 n
的 循环 数组 code
以及一个密钥 k
。
为了获得正确的密码,你需要替换掉每一个数字。所有数字会 同时 被替换。
- 如果
k > 0
, - 将第
i
个数字用 接下来k
个数字之和替换。 - 如果
k < 0
,将第i
个数字用 之前k
个数字之和替换。 - 如果
k == 0
,将第i
个数字用0
替换。
由于 code
是循环的, code[n-1]
下一个元素是 code[0]
,且 code[0]
前一个元素是 code[n-1]
。
给你 循环 数组 code
和整数密钥 k
,请你返回解密后的结果来拆除炸弹!
示例1:
1 | 输入:code = [5,7,1,4], k = 3 |
示例2:
1 | 输入:code = [1,2,3,4], k = 0 |
示例3:
1 | 输入:code = [2,4,9,3], k = -2 |
提示:
n == code.length
1 <= n <= 100
1 <= code[i] <= 100
-(n - 1) <= k <= n - 1
解法一:
Java
1 | public int[] decrypt(int[] code, int k) { |
解法二:
Java
1 | public int[] decrypt(int[] code, int k) { |