一道简单的数位 dp 题 但是脑子里只有 __builtin_popcountll 了呢(自重) 看完题解后很快就理解了,而且有一种这么简单的题居然没想到做法真是不应该唉~的感觉 用 f[i] 表示 1 的位数为 i 且小于 n 的数的个数 然后答案就是 Πif[i] ,而 f[i] 的话从高到低 dp 用组合数乱搞搞一下就可以了 O((lgn)2) 比如说前 i-1 位有 k 位 1 ,第 i 位是 1 ,后面还有 j 位数 然后令第 i 位取 0 ,那么无论后 j 位取了什么数,都比 n 小…