将x> = y转换为1或0而不使用分支或布尔表达式

我需要在没有分支或布尔表达式的情况下实现以下函数
uint8_t func(uint32_t num,uint8_t shl)
{
    if (num >= (1 << shl))
    {
        return shl;
    }
    else
    {
        return 0;
    }
}

我做的第一步是注意到else部分很简单:

return num / (1 << shl);

当然,在if部分中执行此操作不一定会产生所需的结果.

所以我想我需要比num /(1<< shl)更“聪明”的东西了. 如果我能想出一个会给我1或0的表达式,那么我就完成了. 是否有某种方法只使用算术/按位运算(即没有分支或布尔表达式)? 谢谢.

解决方法

您可以将条件视为一个布尔表达式,其计算结果为TRUE(1)或FALSE(0),因此您可以使用以下内容
return (num >= (1 << shl)) * shl;

这段代码通常不是一个好主意,但在无分支约束下,它完成了这项工作.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...