这条代码线在双方图算法中通过BFS做什么
What does this line of code do in bipartite graph algorithm through bfs?
我一直从https://cp-algorithms.com/graph/biparpetite-check.html读取两部分算法,我遇到了一行:
side[u] = side[v] ^ 1
这条代码行有什么作用?^1 是什么?
尝试搜索它,但没有提出任何结果。
^
是C 中的位XOR操作员(也在C,Java等(。
dit(0/1(的位xor,带有1个flips,即。
0 ^ 1 = 1
1 ^ 1 = 0
Wikipedia上给出
位XOR可用于在寄存器中反转选定的位(也称为toggle或flip(。任何位都可以通过用1来切换。
在此算法中,它被用来确定node u
所属的集合。
由于u
和v
已连接(因为u
位于v
的邻接列表中(,因此u
应属于不同集合的 v
(二级值图的属性(。
这些集合被记录在side[]
数组中,该数组存储了两个不相交的顶点集的0或1,而-1
是非专业化值。
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- 警告处理为错误这里有什么问题
- 什么时候调用组成单元对象的析构函数
- #定义c-预处理器常量..我做错了什么
- 努力将整数转换为链表。不知道我在这里做错了什么
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 什么时候在C++中返回常量引用是个好主意
- 如果我只是不访问queue_front节点的子节点,而是将它们推到队列中呢?还是BFS吗
- 当在同一名称空间中有两个具有相同签名的函数时,会发生什么
- C++避免重复声明的语法是什么
- c++库的公共头文件中应该包含什么
- 问题:什么是QAbstractItemView::NoEditTriggers的反面
- 有什么方法可以遍历结构吗
- 当类在C++中定义时,有什么方法可以"register"类吗?
- ifstream什么都没读
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- 这条代码线在双方图算法中通过BFS做什么
- 什么是适用于多个入口和多个出口的类似BFS的最佳路径算法