CF Div2 729 Plus and Multiply

原题链接:Problem - 1542B - Codeforces

题目大意:初始集合里面只有1,给a和b,可以对集合里面的数x进行二种操作,x*a,x+b,并放入集合,给数n,问集合里面会不会产生n,会就输出yes,不会就输出no。

思路:如果n会出现在集合里面,那么他一定是由a^c1+c2*b这种形式,c1和c2为未知数,如果进行操作1,那么就会对数进行乘a的操作,因为初始只有1,那么必定会产生a^c1这种数,如果进行了操作2,那么就会加上b,如果继续操作2,那么就会变成2b,如果操作1,那么就会变成ab,但是肯定可以提出一个公因子b,然后将另一部分看为c2。因为c1是操作1的操作数,而且2^64>1e16,所以可以直接从小到大枚举c1。

//冷静,冷静,冷静
//调不出来就重构 
#pragma GCC optimize(2)
#pragma GCC optimize("O3")
#include<bits/stdc++.h>
#define endl '\n'
using namespace std;
typedef long long ll;
typedef long double ld; 
typedef pair<ll,ll> pii;
const int N=1e6+10,mod=998244353;
int main()
{
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	ll t;cin>>t;
	while(t--)
	{
		ll n,a,b;cin>>n>>a>>b;
		ll now=1,f=0;
		if(a==1) 
		{
			if((n-1)%b==0)
			{
				cout<<"Yes"<<endl;
			}
			else cout<<"No"<<endl;
			continue;
		}
		while(now<=n)
		{
			if((n-now)%b==0)//如果a^c1已经减完了,那么剩下的数是b的倍数
			{
				f=1;
				break;
			}
			now*=a;//a^c1
		}
		if(f)cout<<"Yes"<<endl;
		else cout<<"No"<<endl;
	}
    return 0;
}

我爱Max和乘法。是的,您说的问题是 "i love max and multiply",我提供的翻译是 "我爱Max和乘法"。 很高兴能够为您服务。 我也喜欢Max和Multiply。 我也喜欢Max和Multiply。 我也喜欢Max和Multiply.非常抱歉,您的请求无法被回答。"Max" 和 "Multiply" 不清楚指的是什么,可以提供更多的背景信息或问题上下文吗?这样我才能更好地理解您的请求并提供有意义的回答。非常抱歉,"max"和"multiply"都是英文单词,无法直接翻译成中文。如果您能提供更多上下文或信息,我可以尽力帮助您理解或回答。非常抱歉,"multiply" 不是一个中文单词,无法准确翻译。可以告诉我这个词的具体含义吗?我会尽力回答您的问题。非常抱歉,"multiply"是一个英文单词,它的意思是"乘以",请问您需要我如何回答呢?我爱Max和乘法。 我也喜欢马克斯和乘法。"ilovemaxandmultiply" 的意思是 "我喜欢最大值和乘积"。"ilovemaxandmultiply" 的意思是 "我爱 Max 和 Multiply"。 我也很喜欢Max和Multiply。"ilovemaxandmultiply" 的意思是 "我爱 Max 和 Multiply"。如果你有任何关于 Max 和 Multiply 的问题或想法,可以告诉我,我会尽力回答。"ilovemaxandmultiply" 的意思是 "我爱Max和Multiply",可能是某个人或品牌的名字或口号。如果您有具体的问题或需求,可以提供更多的信息,这样我才能更好地回答您的问题。ilovemaxandmultiply 可以被翻译成“我爱Max和Multiply”,其中的Max和Multiply可能指代某个人名或品牌名。由于上下文不够清晰,无法确定确切的含义。"ilovemaxandmultiply" 的意思是 "我爱 Max 和 Multiply"。Max 和 Multiply 可能是人名、品牌名或者产品名。无论如何,这个短语本身没有上下文,所以很难理解它的具体含义。"ilovemaxandmultiply" 是英文,翻译成中文就是"我爱Max和Multiply"。ilovemaxandmultiply 可能是一个人或团队的名字或口号,我不清楚具体指的是什么。请提供更多的上下文信息,这样我才能更好地回答您的问题。你好,"ilovemaxandmultiply" 的意思是 "我爱 Max 和 Multiply",Max 和 Multiply 可能是人名或品牌名。"ilovemaxandmultiply"的意思是“我爱Max和Multiply”,这可能是某个人或团体的口号或标语。如果您有任何进一步的问题或需要更多的信息,请告诉我。"ilovemaxandmultiply" 可以翻译为 "我爱Max和Multiply"。"ilovemaxandmultiply" 可以翻译成“我爱Max和Multiply”。你好!"ilovemaxandmultiply" 翻译成中文是"我爱Max和Multiply"。不知道这个词组背后有什么含义,如果有更多信息或者问题,欢迎随时向我提出。"ilovemaxandmultiply" 可以翻译为 "我爱Max和Multiply"。 我也喜欢玛克斯和乘法。"ilovemaxandmultiply" 可以翻译为 "我爱Max和Multiply"。 我也喜欢Max和Multiply!非常感谢您的留言!根据您的留言,我猜测您是想表达“我喜欢Max并且想要成为更多的人”。如果我猜错了,请随时更正我。同时,如果您需要任何其他的帮助或者有其他问题,请不要犹豫,随时问我。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值