题意:意思很简单,找一个最接近D且比D大的数,满足它的二进制表示下的1的个数在[S1, S2]之间
分析:从D + 1开始,若个数小于S1,那么从低位向高位把0替换成1直到S1就是最小值,否则往更大的数去找,此时目标是减少1的数量,可以优化, +lowbit (D),因为+小于lowbit (D)只会增加1的数量。这题比赛时队友想的很复杂,方法不够简单暴力。
/************************************************* Author :Running_Time* Created Time :2015/9/28 星期一 09:19:08* File Name :H.cpp ************************************************/#include #include #include #include #include #include #include #include #include #include #include #include #include