C++ 中的逻辑异或

Suraj P 2023年10月12日
  1. C++ 中的逻辑 XOR
  2. 在 C++ 中使用逻辑 XOR 和布尔操作数
  3. 在 C++ 中使用逻辑 XOR 与非布尔操作数
  4. 在 C++ 中使用具有复杂表达式的逻辑 XOR
  5. 在 C++ 中使用 mod 2 操作实现逻辑 XOR
C++ 中的逻辑异或

我们将在本教程中学习如何在 C++ 中实现逻辑 XOR

C++ 中的逻辑 XOR

在 C++ 中,虽然我们有 logical OR (||)logical AND (&&),但我们没有 logical XOR。使用现有的运算符,我们可以模拟逻辑 XOR 的功能。

逻辑 XOR 运算符在 C++ 中不存在,因为它只是一个具有布尔值的等效不等于运算符。

所以一般语法是:A 和 B 是布尔值。

A logical XOR B is equivalent to A!=B

如果我们查看 XOR 的真值表,我们知道 XOR 只不过是布尔值的不等式检查器。所以我们可以使用不等于 (!=) 运算符来模拟逻辑 XOR

在 C++ 中使用逻辑 XOR 和布尔操作数

#include <bits/stdc++.h>
using namespace std;

int main() {
  bool a = 0;
  bool b = 1;

  if (a != b) {
    cout << "Yes\n";
  }

  else
    cout << "NO\n";
}

输出:

Yes

在 C++ 中使用逻辑 XOR 与非布尔操作数

在这里,我们必须进行修改。由于这些值是非布尔值,我们必须先将它们转换为布尔值,然后应用不等于 (!=) 运算符。

#include <bits/stdc++.h>
using namespace std;

int main() {
  int a = 10;
  int b = 20;

  if ((!a) != (!b)) {
    cout << "Yes\n";
  } else
    cout << "NO\n";
}

输出:

NO

我们用了 !这里将值转换为布尔值并将它们取反,以便将两个不相等的正整数 (true) 评估为 false

在 C++ 中使用具有复杂表达式的逻辑 XOR

我们已经了解,我们首先需要将值转换为布尔值,然后执行逻辑 XOR 操作。我们将此想法扩展为对复杂操作执行逻辑 XOR 操作。

#include <bits/stdc++.h>
using namespace std;

int main() {
  int a = 10;
  int b = 20;

  int x = 50;
  int y = 100;

  if (!(a < b) != !(x >= y)) {
    cout << "Yes\n";
  } else
    cout << "NO";
}

我们可以看到 (a<b) Logical XOR (x>=y) 写成!(a < b) != !(x >= y)

输出:

Yes

在 C++ 中使用 mod 2 操作实现逻辑 XOR

在两个布尔值之间实现逻辑 XOR 的另一个方法是使用模 2 运算。A logical XOR B 可以写成 (A+B) % mod 2

#include <bits/stdc++.h>
using namespace std;

bool XOR(bool x, bool y) { return (x + y) % 2; }

int main() {
  cout << "XOR(0, 0): " << XOR(0, 0) << endl;
  cout << "XOR(1, 0): " << XOR(1, 0) << endl;
}

输出:

XOR(0, 0): 0
XOR(1, 0): 1
作者: Suraj P
Suraj P avatar Suraj P avatar

A technophile and a Big Data developer by passion. Loves developing advance C++ and Java applications in free time works as SME at Chegg where I help students with there doubts and assignments in the field of Computer Science.

LinkedIn GitHub

相关文章 - C++ Operator