1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-01-11 02:58:13 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
leetcode-problemset/leetcode-cn/problem (Chinese)/每个查询的最大异或值 [maximum-xor-for-each-query].html
2022-03-29 12:43:11 +08:00

54 lines
2.1 KiB
HTML
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<p>给你一个 <strong>有序</strong> 数组 <code>nums</code> ,它由 <code>n</code> 个非负整数组成,同时给你一个整数 <code>maximumBit</code> 。你需要执行以下查询 <code>n</code> 次:</p>
<ol>
<li>找到一个非负整数 <code>k < 2<sup>maximumBit</sup></code> ,使得 <code>nums[0] XOR nums[1] XOR ... XOR nums[nums.length-1] XOR k</code> 的结果 <strong>最大化</strong> 。<code>k</code> 是第 <code>i</code> 个查询的答案。</li>
<li>从当前数组 <code>nums</code> 删除 <strong>最后</strong> 一个元素。</li>
</ol>
<p>请你返回一个数组 <code>answer</code> ,其中<em> </em><code>answer[i]</code>是第 <code>i</code> 个查询的结果。</p>
<p> </p>
<p><strong>示例 1</strong></p>
<pre>
<b>输入:</b>nums = [0,1,1,3], maximumBit = 2
<b>输出:</b>[0,3,2,3]
<b>解释:</b>查询的答案如下:
第一个查询nums = [0,1,1,3]k = 0因为 0 XOR 1 XOR 1 XOR 3 XOR 0 = 3 。
第二个查询nums = [0,1,1]k = 3因为 0 XOR 1 XOR 1 XOR 3 = 3 。
第三个查询nums = [0,1]k = 2因为 0 XOR 1 XOR 2 = 3 。
第四个查询nums = [0]k = 3因为 0 XOR 3 = 3 。
</pre>
<p><strong>示例 2</strong></p>
<pre>
<b>输入:</b>nums = [2,3,4,7], maximumBit = 3
<b>输出:</b>[5,2,6,5]
<b>解释:</b>查询的答案如下:
第一个查询nums = [2,3,4,7]k = 5因为 2 XOR 3 XOR 4 XOR 7 XOR 5 = 7。
第二个查询nums = [2,3,4]k = 2因为 2 XOR 3 XOR 4 XOR 2 = 7 。
第三个查询nums = [2,3]k = 6因为 2 XOR 3 XOR 6 = 7 。
第四个查询nums = [2]k = 5因为 2 XOR 5 = 7 。
</pre>
<p><strong>示例 3</strong></p>
<pre>
<b>输入:</b>nums = [0,1,2,2,5,7], maximumBit = 3
<b>输出:</b>[4,3,6,4,6,7]
</pre>
<p> </p>
<p><strong>提示:</strong></p>
<ul>
<li><code>nums.length == n</code></li>
<li><code>1 <= n <= 10<sup>5</sup></code></li>
<li><code>1 <= maximumBit <= 20</code></li>
<li><code>0 <= nums[i] < 2<sup>maximumBit</sup></code></li>
<li><code>nums</code> 中的数字已经按 <strong>升序</strong> 排好序。</li>
</ul>