题意
在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; } };