当前位置: 首页 > article >正文

【基础】卒的遍历(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

 代码:

#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;
}


http://www.kler.cn/a/455068.html

相关文章:

  • .NET周刊【12月第3期 2024-12-15】
  • MongoDB 创建用户、User、Role 相关 操作
  • 【已解决】pyinstaller打包ico图片报错:OSError: [WinError 225] 无法成功完成操作,因为文件包含病毒或潜在的垃圾软件。
  • 嵌入式科普(25)Home Assistant米家集成意味着IOT的核心是智能设备
  • 费舍尔信息矩阵全面讲述
  • 探索数据采集
  • dockfile 配置 /etc/apt/source.list.d/debian.list 清华镜像
  • 记录一个制作Fortran的docker镜像
  • 【NODE】01-fs和path常用知识点
  • 【量化策略】波动指数-用Python检测范围和趋势市场
  • Django 管理命令中使用 `logging` 和 输出样式
  • openGauss与GaussDB系统架构对比
  • SpringBoot 依赖之Spring Web
  • 随机游走(Random Walk)
  • 「瑞仕云曜璟庭」多轨交通+成熟配套 杨浦滨江宜居之高地
  • 《第三期(先导课)》之《Python工程应用》
  • 京东零售数据可视化平台产品实践与思考
  • 突破传统,探索单页网站的强大潜力!
  • 论文DiffBP: generative diffusion of 3D molecules for target protein binding
  • [按键精灵IOS安卓版][脚本基础知识]按键post基本写法
  • 适配模式,桥接模式,组合模式,装饰模式和代理模式
  • 利用 deepin-IDE 的 AI 能力,我实现了文件加密扩展
  • ES-聚合分析
  • 【火猫DOTA2】VP一号位透露队伍不会保留原阵容
  • 消息中间件RabbitMQ和kafka
  • QGIS二次开发(地图符号库操作)