第八届“图灵杯”NEUQ-ACM程序设计竞赛个人赛 | 买花

题意

牛客网
在15天内买完n朵花,且不能一天买完,第一天买的数量任意,之后每一天买花的数量为前一天的两倍
如果能刚好买到n朵花,输出YE5(注意不是YES),否则输出N0(注意不是NO)
在这里插入图片描述

思路

假设第一天买了a朵花,那么第二天只能买2a朵,第三天只能买4a朵。
观察到,总共买的花的数量永远是奇数倍的a,即总共买的花的数量能被某个奇数整除,且奇数满足规律 ( 1 < < d a y ) − 1 (1 << day) - 1 (1<<day)1 ,即在二进制上每一位都是1,因为第 d a y day day 天能买到 2 d a y − 1 × a 2^{day-1}\times a 2day1×a朵花。
因为阳阳必须在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;
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值