Frog Jumping Step problem

Source: Internet
Author: User

(1) A frog can jump up to 1 steps at a time, or jump up to 2 levels. Ask the frog to jump on an n-level step with a total number of hops.

(2) A frog can jump up to 1 steps at a time, can also jump on 2 levels ... It can also jump on the N-level, at which point the frog jumps up the level of the N-step total number of hops?


Analysis: 1) when n = 1, there are only 1 hops; when n = 2 o'clock, there are two kinds of jumps; when n = 3 o'clock, there are 3 kinds of jumps; when n = 4 o'clock, there are 5 kinds of jumps; when n = 5 o'clock, there are 8 kinds of jumping method;

The law is similar to the Fibonacci sequence


The code is as follows:

[CPP]View PlainCopy
  1. int Fib (int n)
  2. {
  3. if (n <= 0)
  4. {
  5. cout << "error!" << Endl;
  6. return-1;
  7. }
  8. if (1 = = N)
  9. {
  10. return 1;
  11. }
  12. Else if (2 = = N)
  13. {
  14. return 2;
  15. }
  16. Else
  17. {
  18. return fib (n-1) + fib (n-2);
  19. }
  20. }


2) using FIB (n) to indicate that the frog jumps on the N-Step steps of the number of hops, the frog jumps on the N-Step step number 1 (n-step Jump), set fib (0) = 1;

When n = 1 o'clock, there is only one method of jumping, that is, the 1-Step Jump: Fib (1) = 1;

When n = 2 o'clock, there are two ways of jumping, one-step and second-order jumps: fib (2) = FIB (1) + fib (0) = 2;

When n = 3 o'clock, there are three ways to jump, the first step out of one, followed by FIB (3-1) in the Jump method, the first second out of the second, there is a fib (3-2) in the Jump method, after the first jump out of third order, followed by FIB (3-3) in the Jump method

FIB (3) = FIB (2) + fib (1) +fib (0) = 4;

When n = n, there is a total of n jumps, the first step out of one order, followed by FIB (n-1) in the Jump method, after the first second out of the second, there is a fib (n-2) in the Jump method ..... ..... After the first step out of the N-order, there is a Fib (n-n) jump in the back.

FIB (n) = fib (n-1) +fib (n-2) +fib (n-3) +..........+fib (n-n) =fib (0) +fib (1) +fib (2) +.......+fib (n-1)

And because Fib (n-1) =fib (0) +fib (1) +fib (2) +.......+fib (n-2)

Two-type subtraction: FIB (n)-fib (n-1) =fib (n-1) ===== "fib (n) = 2*fib (n-1) n >= 2

The recursive equation is as follows:

Frog Jumping Step problem

Related Article

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.