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;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

娃娃酱斯密酱

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值