2019年第十届蓝桥杯C++B组国赛E题路径统计

2019年第十届蓝桥杯C++B组国赛E题路径统计

1
原题是这样的。

有一个7X7的方格。方格左上角顶点坐标为(0,0),右下角坐标为(7,7)。
求满足下列条件的路径条数:
1、起点和终点都是(0,0)
2、路径不自交
3、路径长度不大于12
4、对于每一个顶点,有上下左右四个方向可以走,但是不能越界。
例如,图中路线,左上角顶点(0,0),路线长度为10

1
简单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;
}

版权声明:本文为qq_44624316原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。