#include <stdio.h>
#include <math.h>
#ifndef MIN
#define MIN(a, b) ((a) < (b) ? (a) : (b))
#endif
#ifndef MAX
#define MAX(a, b) ((a) > (b) ? (a) : (b))
#endif
int
cal_ones(int a, int b)
{
int ret = 0;
while (a) {
ret |= 1 << (a % 10);
a /= 10;
}
while (b) {
ret |= 1 << (b % 10);
b /= 10;
}
return ret;
}
int
main(int argc, char *argv[])
{
int r3_min, r3_max;
int r4_min, r4_max;
int r_min, r_max;
r3_min = (int)cbrt(1023 - 1) + 1;
r3_max = (int)cbrt(9876 + 1);
r4_min = (int)pow(102345 - 1, 0.25) + 1;
r4_max = (int)pow(987654 + 1, 0.25);
/* 限定范围 */
r_min = MAX(r3_min, r4_min);
r_max = MIN(r4_max, r4_max);
int found = 0;
int age;
for (age = r_min; age <= r_max; age++) {
if (cal_ones(age * age * age, age * age * age * age) == 0x3ff) {
found = 1;
printf("%d\n", age);
}
}
if (!found)
printf("Not found.\n");
return 0;
}