so, here we go
algo: http://www.spoj.com/problems/TAP2013H/
16282. Horace and his primes
Problem code: TAP2013H
Horace likes to play writing natural numbers in the blackboard in his bedroom. One of his favourite games consists in first writing a number n, then the sum of all the different prime numbers that divide n, and so on until the number written on the board becomes a prime number. For example, if Horace begins writing the number n = 90, because 90 = 2 × 32 × 5 the next number to be written will be 2 + 3 + 5 = 10; then, as 10 = 2 × 5 Horace will write the number 2 + 5 = 7; finally, because 7 is a prime number the game will end here.
Formally, in this game each natural number n >= 2 defines a sequence whose first element is n, and each new element is the sum of all the prime numbers that divide the previous element in the sequence. The order of the game is the position of the first prime number in the sequence, and coincides with the total number of numbers written on the blackboard one the game has ended. In the example from the previous paragraph, with n = 90 the order of the game is K = 3, because the numbers that are written will be 90, 10 and 7.
Now, not all games are equally entertaining to Horace, and in this case he prefers to begin by writing a number n such that the order of the corresponding game is a particular value K. Horace would like to know how many different values of n between A and B inclusive satisfy this condition, but because he does not know how to code he needs someone to do this calculation for him. Can you help him?
INPUT
The first line contains an integer P which indicates the number of questions Horace wants to ask you (1 <= P <= 10^5). Each of the next P lines describes a question using three integer numbers A, B and K, which mean that Horace would like to know how many different values of n satisfy that A <= n <= B and the order of the game beggining with n is K (2 <= A <= B <= 10^6 and 1 <= K <= 10^6).
OUTPUT
You should print P lines, each one containing an integer number with the answer to one of the questions made by Horace, in the order in which they appear in the input.
Formally, in this game each natural number n ≥ 2 defines a sequence whose first element is n, and each new element is the sum of all the prime numbers that divide the previous element in the sequence. The order of the game is the position of the first prime number in the sequence, and coincides with the total amount of numbers written on the blackboard once the game has ended. In the example from the previous paragraph, with n = 90 the order of the game is K = 3, because the numbers that are written will be 90, 10 and 7.
Now, not all games are equally entertaining to Horace, and in this case he prefers to begin by writing a number n such that the order of the corresponding game is a particular value K. Horace would like to know how many different values of n between A and B inclusive satisfy this condition, but because he does not know how to code he needs someone to do this calculation for him. Can you help him?
Input
The first line contains an integer P which indicates the number of questions Horace wants to ask you (1 ≤ P ≤ 105). Each of the next P lines describes a question using three integer numbers A, B and K, which mean that Horace would like to know how many different values of n satisfy that A ≤ n ≤ B and the order of the game beginning with n is K (2 ≤ A ≤ B ≤ 106 and 1 ≤ K ≤ 106).
Output
You should print P lines, each one containing an integer number with the answer to one of the questions made by Horace, in the order in which they appear in the input.
Example 1
Input: 1 90 90 3 Output: 1
Example 2
Input: 5 2 9 1 2 9 2 800 810 4 999999 1000000 2 100000 1000000 1000000 Output: 4 4 5 2 0
Added by: | Fidel Schaposnik |
Date: | 2013-10-07 |
Time limit: | 1s-2s |
Source limit: | 50000B |
Memory limit: | 1536MB |
Cluster: | Cube (Intel Pentium G860 3GHz) |
Languages: | All |
Resource: | Argentinian Programming Tournament 2013 |
and here is the solution: http://ideone.com/Lmdgqj
#include <cstdio>
#include <cstring>
#define maxab 1000003
#define maxlv 13
using namespace std;
bool isPrime[maxab];
int sumP[maxab],lv[maxab],c[maxab][maxlv];
int getlv(int i){
if ((lv[i]>0)||(i<=1)) return lv[i];
else {
lv[i]=getlv(sumP[i])+1;
return lv[i];
}
}
void init(){
memset(isPrime,true,sizeof(isPrime));
memset(lv,0,sizeof(lv));
int i,j; isPrime[0]=false; isPrime[1]=false;
for (int i=2;i<maxab;i++) if (isPrime[i]==true){
sumP[i]=i;
lv[i]=1;
for (j=2;(i*j)<=maxab;j++){
isPrime[i*j]=false;
sumP[i*j]+=i;
}
}
for (i=2;i<maxab;i++) getlv(i);
for (i=0;i<=1;i++) for (j=0;j<maxlv;j++) c[i][j]=0;
for (i=2;i<maxab;i++){
for (j=0;j<maxlv;j++) c[i][j]=c[i-1][j];
c[i][lv[i]]++;
}
}
int main(){
init();
int ntest,test,a,b,k;
scanf("%d",&ntest);
for (test=1;test<=ntest;test++){
scanf("%d%d%d",&a,&b,&k);
if (k>=maxlv) printf("0");
else{
printf("%d",c[b][k]-c[a-1][k]);
}
if (test<ntest) printf("\n");
}
return 0;
}
No comments:
Post a Comment