题目取自UVa1583, 侵删。题目如下:
如果x加上x的各位数字之和得到y,就说x是y的生成元。给出n(1<=n<=100000),求最小生成元。无解输出0。例如,n=216, 121, 2005时的解分别为198,0,1979。
分析:
若每输入一个y都循环求最小生成元,当输入多个数据时程序效率难免低下,解决方法时用数组保存1~100000的最小生成元,在输入数据时只需要查表即可得到最小生成元。
参考代码如下:
#include<stdio.h>
#include<string.h>
#define M 100001
int main()
{
int a[M], T, n;
memset(a, 0, sizeof(a));
for(int i = 1; i<=100000; i++){//a[i]中的i
int x = i, y = i;
while(x>0){
y+=x%10;
x/=10;
}
if(a[y]==0||i<a[y]) a[y] = i;
}
scanf("%d", &T);
while(T--){
scanf("%d", &n);
printf("%d\n", a[n]);
}
return 0;
}
从1开始由生成元求y并存入数组,数组下标即为y,内容即为对应的最小生成元x。