如何迭代二进制掩码长的长
How to iterate over binary masks of long long?
如何迭代long long
的唯一(...000010000...
)二进制掩码?我指的是像0001, 0010, 0100, 1000
这样的遮罩
如果你的意思是每个掩码只有一个位集:
for (unsigned long long mask = 1; mask != 0; mask <<= 1) {
// Do something with mask
}
注意,您必须使用unsigned
,以便在移位溢出时定义行为。
我想你不是指所有可能的掩码值;遍历它们需要很长时间
相关文章:
- 位移操作和位掩码未检测到重复字符
- OpenCV - 带有掩码的absdiff
- 生成前缀位掩码
- 如何从__m64值的 lsb 创建 8 位掩码?
- 如何对无符号长 int 进行位掩码?
- 删除K的背景掩码-意味着Python或C++中的集群/
- 如何在C++中优雅地处理位掩码
- 将uint64_t位掩码转换为 std::布尔数组
- 使输入二进制掩码适应 ITK 网格生成器
- 如何从 getifaddr 读取子网掩码
- 优化从子位掩码生成父位掩码
- 基于模式创建位掩码作为 constexpr
- 使用二进制掩码 C++ ITK 获取感兴趣区域
- C++中的运行时位复制(位掩码)
- 根据 IP 和掩码C++打印所有 IP
- C++设置"blank"或重置 ifstrean (ios) 的异常掩码
- OpenCV 检测带有掩码的斑点
- OPENCV:如何创建多边形形状的掩码
- 位掩码和二进制算术
- 如何迭代二进制掩码长的长