给你两个数组:instructions 和 values,数组的长度均为 n。
你需要根据以下规则模拟一个过程:
i = 0 的第一个指令开始,初始得分为 0。instructions[i] 是 "add":
values[i] 加到你的得分中。(i + 1)。instructions[i] 是 "jump":
(i + values[i]) 的指令,但不修改你的得分。当以下任一情况发生时,过程会终止:
i < 0 或 i >= n),或返回过程结束时的得分。
示例 1:
输入: instructions = ["jump","add","add","jump","add","jump"], values = [2,1,3,1,-2,-3]
输出: 1
解释:
从下标 0 开始模拟过程:
"jump",移动到下标 0 + 2 = 2。"add",将 values[2] = 3 加到得分中,移动到下标 3。得分变为 3。"jump",移动到下标 3 + 1 = 4。"add",将 values[4] = -2 加到得分中,移动到下标 5。得分变为 1。"jump",移动到下标 5 + (-3) = 2。示例 2:
输入: instructions = ["jump","add","add"], values = [3,1,1]
输出: 0
解释:
从下标 0 开始模拟过程:
"jump",移动到下标 0 + 3 = 3。示例 3:
输入: instructions = ["jump"], values = [0]
输出: 0
解释:
从下标 0 开始模拟过程:
"jump",移动到下标 0 + 0 = 0。
提示:
n == instructions.length == values.length1 <= n <= 105instructions[i] 只能是 "add" 或 "jump"。-105 <= values[i] <= 105