Hello Readers,
Today i am posting the solution of a "CODECHEF" problem. The problem was asked in the CODE CHEF: October Challenge 2013, known as "Maxim and Dividers".
Here goes the Problem Statement.
Today i am posting the solution of a "CODECHEF" problem. The problem was asked in the CODE CHEF: October Challenge 2013, known as "Maxim and Dividers".
Here goes the Problem Statement.
Problem Statement
- Maxim likes dividers of the numbers. Also Maxim is fond of lucky numbers of small elephant from Lviv city.
If you remember, lucky numbers are positive integers whose decimal representation contains only the lucky digits 4 and 7. For example, numbers 47, 744, 4 are lucky, 5, 17, 467 — aren't.
Now Maxim is interested in the next information: what is the number of the integer positive dividers of number n, which are overlucky.
We call number overlucky if it is possible to remove some, but not all, digits and during bonding the remaining digits we will receive a lucky number. For example, number 72344 — overlucky, because it is possible to remove digits 2 and 3, and get number 744, which is lucky. Number 223 isn't overlucky.
Input
- The first line of the input contains an integer T denoting the number of test cases. The description of Ttest cases follows. Single line of each test case contains an integer n.
Output
- For each test case on different lines print the answer to the problem.
Constraints
- 1 ≤ T ≤ 10
- 1 ≤ n ≤ 10^9
Example
Input: 10 1 2 3 4 5 6 7 8 9 10 Output: 0 0 0 1 0 0 1 1 0 0
First Try it yourself...
Here is my solution in C for the above Problem:
#include<stdio.h>
#include<stdlib.h>
int checkoverlucky(int i)
{
int k;
while(i>0)
{
if(i%10==4||i%10==7)
return 1;
i=i/10;
}
return 0;
}
int main()
{
int T,count=0,i;
int k=0;
long int n;
scanf("%d",&T);
if(T<1||T>10)
{
printf("Error in T");
exit(0);
}
while(k++<T)
{
i=4;
count=0;
scanf("%ld",&n);
if(n<1||n>1000000000)
{
printf("Error in n");
exit(0);
}
while(i<=n)
{
if(n%i==0)
if(checkoverlucky(i))
{
count++;
}
i++;
}
printf("%d \n",count);
}
return 0;
}
Any suggestions are most welcome.. :)
Viva La Raza
Sid