Improve company productivity with a Business Account.Sign Up

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 94
  • Last Modified:

How to compute large factorial values

I am trying to compute a value for 80! (80 factorial) in Java. I have tried both long and BigInteger types without success. I have seen where Guava has a BigIntegerMath class but, unfortunately, I am not allowed to load those jar files. Is there any I can accomplish this without the BigIntegerMath class? If so, can an example be provided?
0
awking00
Asked:
awking00
2 Solutions
 
ste5anSenior DeveloperCommented:
Without success is not an information we can work with. Especially as factorials with BigInteger works.
0
 
frankhelkCommented:
I think "Without success" is another word for "Overflow". 80! is a fairly big number and would bust the long type easily.

You could try with double (and loose precision).

I'fe googled a bit and found out that the Java platform (SE7) supports BigInteger ... so it should be usable to you w/o any external jar (see here for info about that class).

Maybe the class has no overloaded opertors, so you have to use methods to do calculations - i.e. (syntax not checked, more concept ...)

BigInteger a;
BigInteger b;
BigInteger product;

a = someValue;
b = anotherValue;
product = a.multiply(b);

Open in new window

0
 
dpearsonCommented:
I'm not sure what problem you're having with BigInteger.  It should be exactly what you need.
Something along these lines:

		BigInteger fac = new BigInteger("1") ;

		for (int i = 2 ; i <= 80 ; i++) {
			BigInteger multiplier = new BigInteger(Integer.toString(i)) ;
			fac = fac.multiply(multiplier) ;
		}

		System.out.println("Factorial 80 is " + fac) ;

Open in new window

0
Upgrade your Question Security!

Your question, your audience. Choose who sees your identity—and your question—with question security.

 
mccarlIT Business Systems Analyst / Software DeveloperCommented:
Just wanted to point out an alternative to Doug's solution (don't award any points to my comment), it wouldn't be much different in terms of efficiency but just feels better to not convert to strings...
		BigInteger fac = BigInteger.ONE;

		for (int i = 2 ; i <= 80 ; i++) {
			BigInteger multiplier = BigInteger.valueOf(i);
			fac = fac.multiply(multiplier);
		}

		System.out.println("Factorial 80 is " + fac);

Open in new window

0
 
dpearsonCommented:
Oh yeah - mccarl's approach is cleaner.

I'm just used to only using BigInteger when I have a value that needs to be represented as a String so I'm always using the String constructor - but of course that's not necessary here :)

Doug
0
 
mccarlIT Business Systems Analyst / Software DeveloperCommented:
Sorry Doug,

My intention was not to steal points off you, I even asked for no points! :)
0
 
dpearsonCommented:
Haha - no problem mccarl.

Personally I'm none too concerned about the points on EE - I think the goal of just helping people get good advice should be enough and you made this advice better :)

Doug
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Free Tool: IP Lookup

Get more info about an IP address or domain name, such as organization, abuse contacts and geolocation.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Tackle projects and never again get stuck behind a technical roadblock.
Join Now