2019年第十届蓝桥杯C++B组国赛E题路径统计
原题是这样的。
有一个7X7的方格。方格左上角顶点坐标为(0,0),右下角坐标为(7,7)。
求满足下列条件的路径条数:
1、起点和终点都是(0,0)
2、路径不自交
3、路径长度不大于12
4、对于每一个顶点,有上下左右四个方向可以走,但是不能越界。
例如,图中路线,左上角顶点(0,0),路线长度为10
简单dfs。。
就是注意条件路径长度不大于12.
就是在循环内部进行计数即可。要注意路线不能自交。vis[]数组访问。当step>2的时候并且标记了vis[]可以保证路径不自交。
代码部分我是step = 0开始的。进入dfs的时候没有开始计数。
注意边界条件即可。。
注意递归出口条件。
答案是:206
代码部分:
#include <bits/stdc++.h>
using namespace std;
const int N = 10;
int dir[4][2] = {{0, 1}, {1, 0}, {0, -1}, {-1, 0}};
int vis[N][N];
int ans;
void dfs(int x, int y, int s)
{
if (s >= 12)
{
return ;
}
for (int i = 0; i < 4; i++)
{
int tx = x + dir[i][0];
int ty = y + dir[i][1];
if (!tx && !ty && s >= 2 && s <= 11)
{
ans++;
}
if (tx < 0 || tx > 7 || ty < 0 || ty > 7)
{
continue;
}
if (vis[tx][ty])
{
continue;
}
vis[tx][ty] = 1;
dfs(tx, ty, s + 1);
vis[tx][ty] = 0;
}
}
int main()
{
vis[0][0] = 1;
dfs(0, 0, 0);
cout << ans << endl;
return 0;
}