大宝大宝心态好 2021-10-13 05:39 采纳率: 100%
浏览 60
已结题

请问C#有无C++__builtin_系列的高效位运算函数?

C++__builtin_系列函数
•int __builtin_ffs (unsigned int x)
返回x的最后一位1的是从后向前第几位,比如7368(1110011001000)返回4。
•int __builtin_clz (unsigned int x)
返回前导的0的个数。
•int __builtin_ctz (unsigned int x)
返回后面的0个个数,和__builtin_clz相对。
•int __builtin_popcount (unsigned int x)
返回二进制表示中1的个数。
•int __builtin_parity (unsigned int x)
返回x的奇偶校验位,也就是x的1的个数模2的结果

C#中,如果需要计算二进制数的前导0,最高效的做法是什么?

  • 写回答

1条回答 默认 最新

  • 於黾 2021-10-13 06:37
    关注

    没听说过,但是c#可以引用c++写的dll,如果你实在想用,自己封装一下

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
    大宝大宝心态好 2021-10-13 08:27

    调用DLL会带来额外的开销,测试了一下,一个简单的加法运算,C#调用C++非托管代码,效率只有C#直接运算的十五分之一

    一个整数转为二进制后,取前导0的个数,C#难道就没比较高效的计算方法吗?总不能转为二进制字符串后再查找吧?

    回复
    於黾 回复 大宝大宝心态好 2021-10-13 08:40

    你可以跟1<<32位去做与运算,然后31,30,循环,看与到多少变成非0.反正没什么现成的函数可用。

    回复
    大宝大宝心态好 回复 於黾 2021-10-13 08:54

    这个方法行不通,如果有条件判断或循环操作,就没什么效率可言

    回复
    展开全部8条评论
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 10月25日
  • 已采纳回答 10月18日
  • 创建了问题 10月13日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部