Deficient Number
Given a number x, your task is to find if this number is Deficient number or not. A number x is said to be Deficient Number if sum of all the divisors of the number denoted by divisorsSum(x) is less than twice the value of the number x. And the difference between these two values is called the deficiency.
Mathematically, if below condition holds the number is said to be Deficient:
divisorsSum(x) < 2*x
deficiency = (2*x) - divisorsSum(x)
divisorsSum(x) < 2*x
deficiency = (2*x) - divisorsSum(x)
Examples:
Input: 21
Output: YES
Divisors are 1, 3, 7 and 21. Sum of divisors is 32.
This sum is less than 2*21 or 42.
Input: 12
Output: NO
Input: 17
Output: YES
Input:
The first line of input contains an integer T denoting the no of test cases.
Then T test cases follow. Each line contains an integer x.
Output:
For each test case in a new line print 1 if the no is a Deficient number else print 0.
The first line of input contains an integer T denoting the no of test cases.
Then T test cases follow. Each line contains an integer x.
Output:
For each test case in a new line print 1 if the no is a Deficient number else print 0.
Constraints:
1<=T<=10000
1<=x<=10000
1<=T<=10000
1<=x<=10000
Example:
Input:
3
21
12
17
Output:
1
0
1
Program:
#include<stdio.h>
#include<conio.h>
int main()
{
int
a[10000],t=0,n,i,j,divisor[10000],deficient;
scanf("%d",&n);
for(i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
for(i=0;i<n;i++)
{
for(j=1; j
<= a[i]; j++)
{
if (a[i]%j == 0)
{
t=t+j;
}
}
divisor[i]=t;
t=0;
}
for(i=0;i<n;i++)
{
deficient=2*a[i];
if(deficient>divisor[i])
{
printf("1\n");
}
else
{
printf("0\n");
}
}
getch();
return 0;
}
Comments
Post a Comment