题意:输入为一个数n(n<=10^6),问在n位数中,平方的后9位为987654321的数有多少个?
思路:显然,n(n>9)位数平方的后9位只与n的后9位有关,所以,只要求出9位数中有多少个平方后9位为987654321即可。而n位数首位数取自1~9,2~n-9位数取自0~9.
而9位数有多少个符合题意也是用上述思路,并不是暴搜。结果得到n小于9时没有符合题意的数,n为9时有8个符合题意。所以原题的代码为:
#include <stdio.h>
int n;
int main(){
scanf("%d",&n);
if(n <= 8)
printf("0\n");
else if(n == 9)
printf("8\n");
else{
printf("72");
for(;n>10;n--)
printf("0");
printf("\n");
}
return 0;
}
而之前搜索的代码为:
#include <stdio.h>
#include <string.h>
#include <math.h>
__int64 s[100000];
int op[9] = {1,2,3,4,5,6,7,8,9};
int num[10];
int test(__int64 x,int digit){//判断后digit位
int i;
for(i = 0;i<digit;i++){
if(x%10!=op[i])
return 0;
x/=10;
}
return 1;
}
int main(){
int i,j,k,a,b,c;
memset(num,0,sizeof(num));
s[0] = 1;s[1] = 9;
a = 0;b = 1;//ab为一次搜索的上下界
for(i = 2;i<=9;i++){
c=b;
for(j = a;j<=c;j++){//搜索i-1位数
for(k = 0;k<=9;k++){//注意k从0开始
__int64 temp = k*(__int64)pow(10,i-1)+s[j];//i位数这样构成,并不是暴搜
if(test(temp*temp,i))//后i位符合,入队
s[++b] = temp;
if(test(temp*temp,9))
num[i]++;
}
}
a = c+1;
}
}