把下面这句话翻译成中文,保留html代码,不用增加新内容:
我们被给予一个大小为N(4的倍数的大小)的整数数组,我们必须
对数组执行异或运算,使得 input[1- 4] 类似于
utility_arr[1- 4]和计算条件是如果arr[1 – 4] = {a1, a2, a3, a4}
那么 q[1 – 4] = {a1 ⊕ a2 ⊕ a3, a1 ⊕ a2 ⊕ a4, a1 ⊕ a3 ⊕ a4, a2 ⊕ a3 ⊕ a4}
让我们看看这种情况的各种输入输出场景 -
In − int[] input = { 5, 2, 3, 4 };
Out − 异或后的结果运算 4 3 2 5
解释−异或门的输出仅在其两个输入端子处于“不同”逻辑电平时才变为“高”。如果这两个输入 A 和 B 都处于逻辑电平“1”或“0”,则输出为“0”,从而使门成为“奇数门但不是偶数门”。换句话说,当输入有奇数个 1 时,输出为“1”。
a1 ⊕ a2 ⊕ a3 = 5 ⊕ 2 ⊕ 3 = 4
a1 ⊕ a2 ⊕ a4 = 5 ⊕ 2 ⊕ 4 = 3
a1 ⊕ a3 ⊕ a4 = 5⊕ 3 ⊕ 4 = 2
a2 ⊕ a3 ⊕ a4 = 2 ⊕ 3 ⊕ 4 = 5
In − int[] input = { 7, 6, 4, 4, 3, 8, 9, 5 };
Out − XOR 运算后的结果 5 5 7 6 2 14 15 4
说明− 异或门的输出仅在其两个输入时变为“高”终端处于彼此“不同”的逻辑电平。如果这两个输入 A 和 B 都处于逻辑电平“1”或“0”,则输出为“0”,从而使门成为“奇数门但不是偶数门”。换句话说,当输入有奇数个 1 时,输出为“1”。仅适用于大小为 4 倍数的 input[],其他大小的输入数组将显示 0 代替奇数位置的数字。
异或运算后的结果 5 5 7 6 2 14 15 4
下面程序中使用的方法如下 -
-
根据 XOR a ⊕ a = 0 和 a ⊕ 0 = a 的性质。 (a ⊕ b ⊕ c) ⊕ (b ⊕ c ⊕ d) = a ⊕ d (As (b ⊕ c) ⊕ (b ⊕ c) = 0)
-
对于计算时将数组分为 4 组,我们将按照 XOR 的性质来计算每组的结果。
-
参考上述性质,使用 (a ⊕ d )我们可以计算b和c
(a ⊕ b ⊕ d) ⊕ (a ⊕ d) = b
(a ⊕ c ⊕ d) ⊕ (a ⊕ d) = c -
通过使用 b 和 c,我们可以使用以下方法得到 a 和 d
(a ⊕ b ⊕ c) ⊕ (b) ⊕ (c) = a
(b ⊕ c ⊕ d) ⊕ (b) ⊕ (c) = d -
对所有四组重复该过程
-
使用 2 个指针 i 和 j 迭代循环,直到数组的长度除以四,并引入临时值(ans)和实用程序数组(存储答案)。
-
在 for 循环内实现以下异或运算
ans= 输入数组[i] ⊕ 输入数组[i+3]
实用程序数组[i+1](计算 b)= 输入数组[i+1] ⊕ ans
实用数组[i+2](计算 c)= 输入数组[i+2] ⊕ ans
实用数组[i](计算a)=输入数组[i]⊕((效用数组[i + 1])^(效用数组[i + 2]))
效用数组[i](计算d) )= input array[i+3] ⊕ ((Utility array[i + 1]) ^ (Utility array[i + 2]))
-
并且指针被更新对于下一组四个字符
-
最后,打印数组并将结果返回给用户。
示例
import java.util.Arrays;
import java.util.List;
public class Tutorials{
static int ans = 0;
public static void main(String args[]){
int[] input = {7, 1, 2, 3};
int[] arr = new int[input.length];
for (int i = 0, j = 0; j < input.length / 4; j++){
ans = input[i] ^ input[i + 3];
arr[i + 1] = input[i + 1] ^ ans;
arr[i + 2] = input[i + 2] ^ ans;
arr[i] = input[i] ^ ((arr[i + 1]) ^ (arr[i + 2]));
arr[i + 3] = input[i + 3] ^ (arr[i + 1] ^ arr[i + 2]);
i += 4;
}
System.out.println("Different XORs of elements in groups of size 4 is: ");
for (int i = 0; i < arr.length; i++){
System.out.println(arr[i]);
}
}
}
登录后复制
输出
如果我们运行上面的代码,将会生成以下输出
Different XORs of elements in groups of size 4 is :
4
5
6
0
登录后复制
以上就是在Java中,使用大小为4的组对元素进行不同的XOR操作来查找数组的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!