solution.md 1.2 KB
Newer Older
每日一练社区's avatar
每日一练社区 已提交
1 2 3 4 5
# 振兴中华

小明参加了学校的趣味运动会,其中的一个项目是:跳格子。  

地上画着一些格子,每个格子里写一个字,如下所示:
每日一练社区's avatar
每日一练社区 已提交
6

每日一练社区's avatar
每日一练社区 已提交
7 8 9 10 11 12
```
从我做起振
我做起振兴
做起振兴中
起振兴中华
```
每日一练社区's avatar
每日一练社区 已提交
13

每日一练社区's avatar
每日一练社区 已提交
14
![](https://img-blog.csdn.net/20180327194316347)  
每日一练社区's avatar
每日一练社区 已提交
15

每日一练社区's avatar
每日一练社区 已提交
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
比赛时,先站在左上角的写着“从”字的格子里,可以横向或纵向跳到相邻的格子里,但不能跳到对角的格子或其它位置。一直要跳到“华”字结束。

要求跳过的路线刚好构成“从我做起振兴中华”这句话。

请你帮助小明算一算他一共有多少种可能的跳跃路线呢?

以下代码实现了这一功能,请你填补空白处内容:

```cpp
#include <iostream>
using namespace std;

int f(int x, int y)
{
    if (x == 3 || y == 4)
        return 1;
    __________________
}
int main()
{
    cout << f(0, 0) << endl;
    return 0;
}
```

## aop

### before

```cpp

```

### after

```cpp

```

## 答案

```cpp
return f(x + 1, y) + f(x, y + 1);
```

## 选项

### A

```cpp
return f(x - 1, y) + f(x, y - 1);
```

### B

```cpp
return f(x + 1, y) + f(x, y - 1);
```

### C

```cpp
return f(x + 1, y + 1) + f(x + 1, y + 1);
```