先贴代码,以后再写题解... 首先,直接枚举肯定是会超时的,毕竟n就有10^9那么多... 对于每个数,我们先把它转化为二进制:例:21-->10101: 对于00001~10101,可以分为几个部分: 00001~10000: 10001~10100: 10101 因为对于每个数,从最右边的1截断,于是就可以理解为为: 00001~10000:: 001~100: 1: 设s[i]为二进制从右边数第 i+1 个数为1 (且其他数都为0)的lowbit sum: 则 s[i]=s[i-1]*2+…