sgu 107 找最后9位是987654321的数

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


你可能感兴趣的:(sgu 107 找最后9位是987654321的数)