题意
在15天内买完n朵花,且不能一天买完,第一天买的数量任意,之后每一天买花的数量为前一天的两倍
如果能刚好买到n朵花,输出YE5(注意不是YES),否则输出N0(注意不是NO)
思路
假设第一天买了a朵花,那么第二天只能买2a朵,第三天只能买4a朵。
观察到,总共买的花的数量永远是奇数倍的a,即总共买的花的数量能被某个奇数整除,且奇数满足一定的规律((1 << day) - 1,即在二进制上每一位都是1)。
因为阳阳必须在15天内买完他要的花,所以那个奇数最大只能是32767,我们只需要枚举其中的每个奇数,看看能不能被整除即可。整除得到的商就是第一天买的花的数量
代码
#include <iostream>
using namespace std;
int main() {
int T;
int n;
cin >> T;
while (T-- > 0) {
cin >> n;
//不能一天买完,所以从2开始
int day = 2;
for (; day <= 15; ++day) {
if (n % ((1 << day) - 1) == 0) {
cout << "YE5" << endl;
break;
}
}
if (day == 16)cout << "N0" << endl;
}
};
京公网安备 11010502036488号