recursive solution for finding total no of ways...
T(n) = Sigma (-1)^(m+1)*[ T(n-m*(3*m-1)/2) + T (n-m*(3*m+1)/2)]
where m = 1,2,3.........until (n-m*(3*m+1)/2) > 0;
Example:
T(5) = T(4) +T(3) - T(0)
//------------------------------------------------------------------------------------------------------------//
int T(int n)
{
if(n < 0)
return 0;
else
{
if(n == 0)
return 1;
else
{
int temp = 1;
int tempr = 0;
int m = 0;
while(temp > 0)
{
m++;
temp = n-m*(3*m+1)/2;
tempr += pow(-1,m+1)*T(n-m*(3*m-1)/2) +
pow(-1,m+1)*T(n-m*(3*m+1)/2);
}
return tempr;
}
}
}
int main()
{
int number;
scanf("%d",number;);
printf("\nTotal ways = %d",T(number));
}
//------------------------------------------------------------------------------------------------------------//
No comments:
Post a Comment