今天的题目是1652. Defuse the Bomb。
你有一个炸弹需要拆除,时间紧迫!你的情报员会给你一个长度为 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:
示例 2:
示例 3:
提示:
n == code.length
1 <= n <= 100
1 <= code[i] <= 100
-(n - 1) <= k <= n - 1
简单题,一个[[前缀和]]就搞定了。
解决循环数组的话,可以用一个n+k+1
长度的前缀数组,在计算前缀和的时候展开循环数组的部分。
而k<0
的情况,可以简单的转置数据来解决。