Given a number n, find n-th Fibonacci Number. Note that n may be large.
Input : 100 Output : 218922995834555169026 Input : 500 Output : 8616829160023845073278831216566478809594 1068326060883324529903470149056115823592 713458328176574447204501
Fibonacci of large number may contain more than 100 digits, it can be easily handled by BigInteger in Java. BigInteger class is used for mathematical operation which involves very big integer calculations that are outside the limit of all available primitive data types.
268638100244853593861467272021429239676 166093189869523401231759976179817002478 816893383696544833565641918278561614433 563129766736422103503246348504103776803 673341511728991697231970827639856157644 50078474174626
Note that the above solution takes O(n) time, we can find n-th Fibonacci number in O(Log n) time. As an exercise, find n-th Fibonacci number for large n in O(Log n) time.
This article is contributed by Pramod Kumar. If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to firstname.lastname@example.org. See your article appearing on the GeeksforGeeks main page and help other Geeks.
Please write comments if you find anything incorrect, or you want to share more information about the topic discussed above.
- Generating large Fibonacci numbers using boost library
- GCD of two numbers when one of them can be very large
- LCM of two large numbers
- Sum of two large numbers
- Difference of two large numbers
- Divisible by 37 for large numbers
- Remainder with 7 for large numbers
- Find Last Digit of a^b for Large Numbers
- Sort an array of large numbers
- Sum of first N natural numbers when N is extremely large
- Non Fibonacci Numbers
- Sum of Fibonacci Numbers
- GCD and Fibonacci Numbers
- Even Fibonacci Numbers Sum
- Last digit of Product of two Large or Small numbers (a * b)