从小到大枚举s(x,m)的值,解出x的值,看看是否满足x^2+s(x,m)x-n=0,如果满足则输出x。
因为1<=n<=10^18,2<=m<=16,所以sum(x,m)的值不会超过1000
#include<stdio.h>
#include<math.h>
#define ll long long
ll s(ll x,ll m)
{
ll ans=0;
while(x)
{
ans+=x%m;
x/=m;
}
return ans;
}
int main()
{
int t;
ll n,m;
scanf("%d",&t);
while(t--)
{
scanf("%I64d%I64d",&n,&m);
int flag=0;
ll x;
for(int i=1;i<=200;i++)
{
x=(-i+sqrt(i*i+4*n))/2;
if(x*x+s(x,m)*x-n==0)
{
flag=1;
break;
}
}
if(flag==0)
printf("-1\n");
else
printf("%I64d\n",x);
}
return 0;
}