大家好,欢迎来到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