美素数
Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Total Submission(s): 5743 Accepted Submission(s): 2017
Problem Description
小明对数的研究比较热爱,一谈到数,脑子里就涌现出好多数的问题,今天,小明想考考你对素数的认识。
问题是这样的:一个十进制数,如果是素数,而且它的各位数字和也是素数,则称之为“美素数”,如29,本身是素数,而且2+9 = 11也是素数,所以它是美素数。
给定一个区间,你能计算出这个区间内有多少个美素数吗?
问题是这样的:一个十进制数,如果是素数,而且它的各位数字和也是素数,则称之为“美素数”,如29,本身是素数,而且2+9 = 11也是素数,所以它是美素数。
给定一个区间,你能计算出这个区间内有多少个美素数吗?
Input
第一行输入一个正整数T,表示总共有T组数据(T <= 10000)。
接下来共T行,每行输入两个整数L,R(1<= L <= R <= 1000000),表示区间的左值和右值。
接下来共T行,每行输入两个整数L,R(1<= L <= R <= 1000000),表示区间的左值和右值。
Output
对于每组数据,先输出Case数,然后输出区间内美素数的个数(包括端点值L,R)。
每组数据占一行,具体输出格式参见样例。
每组数据占一行,具体输出格式参见样例。
Sample Input
3 1 100 2 2 3 19
Sample Output
Case #1: 14 Case #2: 1 Case #3: 4利用素数打表的方式找出美素数,然后利用线段树的方式进行输出,不然容易超时。。#include<stdio.h> #include<string.h> int a[1000000+10]; int ans[1000000+10]; int t,n,i,j,k,x,y,l=1; void db() { memset(a,0,sizeof(a)); a[1]=1; for(i = 2; i <= 1000000; i ++) { if(a[i] == 1) continue; for(j = 2 * i; j <= 1000000; j += i) a[j] = 1; } for(i=2;i<=1000000;i++) { int sum=0; if(a[i]==1) ans[i]=ans[i-1]; else { t=i; while(t>=1) { sum+=t%10; t=t/10; } if(a[sum]==1) ans[i]=ans[i-1]; else ans[i]=ans[i-1]+1; } } } int main() { scanf("%d",&n); ans[0]=0,ans[1]=0; db(); while(n--) { scanf("%d%d",&x,&y); printf("Case #%d: ",l++); printf("%d\n",ans[y]-ans[x-1]); } return 0; }