题意:给定两个数n和m,找出n的所有因子(约数),将每个约数表示成m进制,然后求此m进制的每一位上的数的平方和。
解题思路:暴力求解,详见代码。
Code:
#include <iostream>
#include <cmath>
#include <cstdio>
using namespace std;
int vis[100];
int main()
{
//freopen("input.txt","r",stdin);
int n,m,sum;
while(~scanf("%d%d",&n,&m))
{
sum = 0;
for(int i = 1; i <= (int)sqrt(n*1.0); i++)
{
if(n%i == 0)
{
int temp1 = i;
int temp2 = n/i;
while(temp1)
{
sum +=(temp1%m)*(temp1%m);
temp1/=m;
}
if(i == temp2) continue;
while(temp2)
{
sum +=(temp2%m)*(temp2%m);
temp2/=m;
}
}
}
int len = 0;
while(sum)
{
vis[len++] = sum%m;
sum/=m;
}
for(int j = len-1; j >= 0; j--)
{
if(vis[j] > 9)printf("%c",vis[j]-10+'A');
else printf("%d",vis[j]);
}
printf("\n");
}
return 0;
}