diff options
Diffstat (limited to 'challenge-173/mohammad-anwar/java/theweeklychallenge/SylvesterSequence.java')
| -rw-r--r-- | challenge-173/mohammad-anwar/java/theweeklychallenge/SylvesterSequence.java | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/challenge-173/mohammad-anwar/java/theweeklychallenge/SylvesterSequence.java b/challenge-173/mohammad-anwar/java/theweeklychallenge/SylvesterSequence.java new file mode 100644 index 0000000000..8f4400e4e0 --- /dev/null +++ b/challenge-173/mohammad-anwar/java/theweeklychallenge/SylvesterSequence.java @@ -0,0 +1,65 @@ +package theweeklychallenge; + +/* + +Week 173: + + https://theweeklychallenge.org/blog/perl-weekly-challenge-173 + +Task #2: Sylvester’s sequence + + Write a script to generate first 10 members of Sylvester's sequence. + +Compile and Run: + + mohammad-anwar/java$ javac theweeklychallenge/SylvesterSequence.java + mohammad-anwar/java$ java theweeklychallenge.SylvesterSequence + +*/ + +import java.lang.Math; +import java.util.Arrays; +import java.util.ArrayList; +import java.math.BigInteger; +import junit.framework.TestCase; +import static junit.framework.Assert.*; + +public class SylvesterSequence extends TestCase { + + public static void main(String[] args) { + junit.textui.TestRunner.run( + theweeklychallenge.SylvesterSequence.class); + } + + public void testSylvesterSequence() { + BigInteger exp[] = { + BigInteger.valueOf(2) + ,BigInteger.valueOf(3) + ,BigInteger.valueOf(7) + ,BigInteger.valueOf(43) + ,BigInteger.valueOf(1807) + ,BigInteger.valueOf(3263443) + ,new BigInteger("10650056950807") + ,new BigInteger("113423713055421844361000443") + ,new BigInteger("12864938683278671740537145998360961546653259485195807") + ,new BigInteger("165506647324519964198468195444439180017513152706377497841851388766535868639572406808911988131737645185443") + }; + + BigInteger got[] = sylvesterSequence(10); + + assertTrue(Arrays.equals(exp, got)); + } + + public static BigInteger[] sylvesterSequence(int n) { + ArrayList<BigInteger> _ss = new ArrayList<BigInteger>(); + _ss.add(BigInteger.valueOf(2)); + int i = 1; + while (i++ <= n - 1) { + BigInteger m = _ss.get(_ss.size() - 1); + _ss.add((m.multiply(m.subtract(BigInteger.valueOf(1)))).add(BigInteger.valueOf(1))); + } + + BigInteger[] ss = new BigInteger[_ss.size()]; + return _ss.toArray(ss); + } +} |
