To calculate factorial for a big number we need to use integer array as factrial value wont fit in the
size of the integer.
Ex:
2432902008176640000 = 20!
51090942171709440000 = 21!
8222838654177922817725562880000000 = 31!
263130836933693530167218012160000000 = 32
295232799039604140847618609643520000000 = 34!
Create and integer array and initialize with 0. In every iteration stored value(val) is multiplied and val%10 value will be stored in current index and val/10 will be added ( carry forwarded) to next number.Here multiplier will be incremented by one for each iteration
ex:
5! = 120;
a = {0,0,0,0,0};
i=1;
a = {1,0, 0,0,0};
i=2;
a = {2,0,0,0,0};
i=3;
a= {6,0,0,0,0};
i=4;
a={4,2,0,0,0};
i=5;
a={0,2,1,0,0}
reverse array and print output.
code
-------
size of the integer.
Ex:
2432902008176640000 = 20!
51090942171709440000 = 21!
8222838654177922817725562880000000 = 31!
263130836933693530167218012160000000 = 32
295232799039604140847618609643520000000 = 34!
Create and integer array and initialize with 0. In every iteration stored value(val) is multiplied and val%10 value will be stored in current index and val/10 will be added ( carry forwarded) to next number.Here multiplier will be incremented by one for each iteration
ex:
5! = 120;
a = {0,0,0,0,0};
i=1;
a = {1,0, 0,0,0};
i=2;
a = {2,0,0,0,0};
i=3;
a= {6,0,0,0,0};
i=4;
a={4,2,0,0,0};
i=5;
a={0,2,1,0,0}
reverse array and print output.
code
-------
#include <iostream> using namespace std; int main() { int a[200]={0};
//100 factorial int carry=1,m=1,n=100,j,val,i; for(i=1;i<=n;i++) { j=0; while( j < m || carry !=0 ) { val = a[j]*i + carry; a[j] = val % 10; carry = val/10; j++; } m = j; } for(i=m-1;i>=0;i--) cout<<a[i]; }
No comments:
Post a Comment