那我们就
while(tmp<l) { tmp*=k; cnt++; }
这样一下~ 然后cnt就能说明一切啦~ 啊需要注意的是,超过范围但是发现不是某次幂要记得判断哦~
#include <cstdio>
#include <string>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
typedef long long ll;
// http://codeforces.com/contest/114
// Cifera
int main()
{
int cnt=0;
ll k,tmp,l; cin>>k>>l; tmp=k;
while(tmp<l)
{
tmp*=k;
cnt++;
}
if(tmp==l)cout<<"YES"<<endl<<cnt;
else cout<<"NO";
return 0;
}

本文介绍了一个趣味数学挑战——Petya发明了一种表示数字的方式:使用la的数量来表示数字的重要程度。文章详细解释了如何判断一个数字是否属于这种表示方式,并提供了一个简单的算法实现。
1737

被折叠的 条评论
为什么被折叠?



