【基础】卒的遍历(DFS)

题目描述

在一张n*m的棋盘上(如6行7列)的最左上角(1,1)的位置有一个卒。该卒只能向下或者向右走,且卒采取的策略是先向下,下边走到头就向右,请问从(1,1)点走到(n,m)点可以怎样走,输出这些走法。

输入

两个整数n,m代表棋盘大小(3=<n<=8,3<=m<=8)

输出

卒的行走路线

样例输入 复制
复制代码
3 3
样例输出 复制
复制代码
1:1,1->2,1->3,1->3,2->3,3
2:1,1->2,1->2,2->3,2->3,3
3:1,1->2,1->2,2->2,3->3,3
4:1,1->1,2->2,2->3,2->3,3
5:1,1->1,2->2,2->2,3->3,3
6:1,1->1,2->1,3->2,3->3,3

代码:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int n,m,ans=0,vis[15][15];
int dx[4]= {1,0},dy[4]= {0,1};
struct te {
	int dx;
	int dy;
};
te a[20];
void dfs(int x,int y,int step) {
	if(x==n&&y==m) {
		a[step].dx=x;
		a[step].dy=y;
		ans++;
		cout<<ans<<":"<<a[0].dx<<","<<a[0].dy;
		for (int i=1; i<=step; i++) {
			cout<<"->"<<a[i].dx<<","<<a[i].dy;
		}
		cout<<endl;
	}
	vis[x][y]=1;
	a[step].dx=x;
	a[step].dy=y;
	for (int i=0; i<2; i++) {
		int tx=x+dx[i],ty=y+dy[i];
		if(tx>0&&ty>0&&tx<=n&&ty<=m&&vis[tx][ty]==0) {
			step++;
			dfs(tx,ty,step);
			vis[tx][ty]=0;
			step--;
		}
	}
}
int main() {
    cin>>n>>m;
	dfs(1,1,0);
	return 0;
}
相关推荐
@我漫长的孤独流浪9 分钟前
程序综合实践第十二周-二叉树
算法·深度优先·图论
啊阿狸不会拉杆9 分钟前
《数字图像处理》第 3 章 - 灰度变换与空间滤波
图像处理·人工智能·算法·计算机视觉·数字图像处理
执笔论英雄10 分钟前
【RL 】Ray 支持RDMA
算法
Keep_Trying_Go11 分钟前
统一的人群计数训练框架(PyTorch)——基于主流的密度图模型训练框架
人工智能·pytorch·python·深度学习·算法·机器学习·人群计数
(●—●)橘子……12 分钟前
记力扣557.反转字符串中的单词 练习理解
算法·leetcode·职场和发展
啊阿狸不会拉杆19 分钟前
《数字图像处理 》 第 1 章-绪论
图像处理·python·opencv·算法·数字图像处理
智驱力人工智能24 分钟前
加油站静电夹检测 视觉分析技术的安全赋能与实践 静电夹检测 加油站静电夹状态监测 静电接地报警器检测
人工智能·深度学习·算法·安全·yolo·边缘计算
断剑zou天涯32 分钟前
【算法笔记】线段树SegmentTree
数据结构·笔记·算法
眠りたいです35 分钟前
基于脚手架微服务的视频点播系统-服务端开发部分(补充)文件子服务问题修正
c++·微服务·云原生·架构
ULTRA??1 小时前
各种排序算法时间复杂度分析和实现和优势
c++·python·算法·排序算法