给你一个整数数组 nums。
将数组划分为 三 个(可以为空)子序列 A、B 和 C,使得 nums 中的每个元素 恰好 属于一个子序列。
你的目标是 最大化 以下值:XOR(A) + AND(B) + XOR(C)
其中:
XOR(arr) 表示 arr 中所有元素的按位异或结果。如果 arr 为空,结果定义为 0。AND(arr) 表示 arr 中所有元素的按位与结果。如果 arr 为空,结果定义为 0。返回可实现的最 大 值。
注意: 如果有多种划分方式得到相同的 最大 和,你可以按其中任何一种划分。
子序列 是指一个数组通过删除一些或不删除任何元素,不改变剩余元素的顺序得到的元素序列。
示例 1:
输入: nums = [2,3]
输出: 5
解释:
一个最优划分是:
A = [3], XOR(A) = 3B = [2], AND(B) = 2C = [], XOR(C) = 0最大值为: XOR(A) + AND(B) + XOR(C) = 3 + 2 + 0 = 5。因此,答案是 5。
示例 2:
输入: nums = [1,3,2]
输出: 6
解释:
一个最优划分是:
A = [1], XOR(A) = 1B = [2], AND(B) = 2C = [3], XOR(C) = 3最大值为: XOR(A) + AND(B) + XOR(C) = 1 + 2 + 3 = 6。因此,答案是 6。
示例 3:
输入: nums = [2,3,6,7]
输出: 15
解释:
一个最优划分是:
A = [7], XOR(A) = 7B = [2,3], AND(B) = 2C = [6], XOR(C) = 6最大值为: XOR(A) + AND(B) + XOR(C) = 7 + 2 + 6 = 15。因此,答案是 15。
提示:
1 <= nums.length <= 191 <= nums[i] <= 109