题意:输入为一个数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; } }