CF1542 B. Plus and Multiply
阿新 • • 發佈:2021-09-24
題意:
若x在集合裡,則x*a和x+b都在集合裡
初始集合裡只有1,給出n,問n是否在集合裡
x先乘a再加b得到x*a+b
x先加b再乘a得到x*a+b*a
所以x先乘a再加a次b等價於x先加b再乘a
所有的集合裡的數都可以表示為x*a^i+b*j
若a!=1,列舉i
若a=1,直接解
#include<bits/stdc++.h> using namespace std; int main() { int T,n,a,b; long long aa; bool tag; scanf(作者:xxy 出處:http://www.cnblogs.com/TheRoadToTheGold/ 本文版權歸作者和部落格園共有,轉載請用連結,請勿原文轉載,Thanks♪(・ω・)ノ。"%d",&T); while(T--) { scanf("%d%d%d",&n,&a,&b); tag=false; if(a!=1) { aa=1; for(int i=1;aa<=n;aa*=a) if(!((n-aa)%b)) { tag=true; break; } }else if(!((n-1)%b)) tag=true; puts(tag ? "YES" : "NO"); } }