【模板】popcount

【模板】popcountpostedon2022-02-0418:11:33|under模板|sourceintpopcount(intx){#defineBIT2(n)n,n+1,n+1,n+2#defineBIT4(n)BIT2(n),BIT2(n+1),BIT2(n+1),BIT2(

大家好,欢迎来到IT知识分享网。

posted on 2022-02-04 18:11:33 | under 模板 | source

int popcount(int x){
    #define BIT2(n) n,n+1,n+1,n+2
    #define BIT4(n) BIT2(n),BIT2(n+1),BIT2(n+1),BIT2(n+2)
    #define BIT6(n) BIT4(n),BIT4(n+1),BIT4(n+1),BIT4(n+2)
    #define BIT8(n) BIT6(n),BIT6(n+1),BIT6(n+1),BIT6(n+2)
    static const char popc[1<<8]={BIT8(0)};
    return popc[x&0xff]+popc[x>>8&0xff]+popc[x>>16&0xff]+popc[x>>24&0xff];
}
int popcount(int x){return x?popcount(x&x-1)+1:0;}

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/30288.html

(0)

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

关注微信