裴蜀定理

Alice认为4和7是幸运数字,并且如果一个数字是几个幸运数字的和,那么这个数字也是幸运数字,例如

    14=7+7
    18=7+7+4
    11=7+4
    7=7

现在给你Q个数字,请你分别判断每个数字是否为幸运数字

数据输入
输入共Q+1行,第一行一个数字代表数字个数,接下来Q行,每行一个数字x

    1≤Q≤100
    1≤x≤1016

数据输出
输出共Q行,每行对应输入的数字是否为幸运数字。若是则输出"Yes",否则输出"No"
样例
输入样例1

4
1
4
11
17

输出样例1

No
Yes
Yes
No

这道题我本来以为用欧几里得做,结果发现是用裴蜀定理来做的,定理:两个互质的数不能表示的数是(a-1)*(b-1)-1

#include <cstdio>
 
int main(void)
{
    int q,x,i;
    int notLucky[]={1,2,3,5,6,9,10,13,17};
    int N=sizeof(notLucky)/sizeof(notLucky[0]);
    scanf("%d",&q);
    while(q--)
    {
        scanf("%d",&x);
        for(i=0;i<N;i++)
            if(x==notLucky[i])
                break;
        if(i==N)
            printf("Yes\n");
        else
            printf("No\n");
    }
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值