东方博宜OJ 【基础】卒的遍历

2023-10-20 06:10
文章标签 基础 遍历 oj 东方 博宜

本文主要是介绍东方博宜OJ 【基础】卒的遍历,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述

在一张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;
int r[20][3];//存储行走路径 
//方向的变化 
int fx[3] = {0,1,0};
int fy[3] = {0,0,1}; 
int c;//计数器 void print(int k){c++;cout<<c<<":";//除了最后一个点以外 for(int i = 1;i < k;i++){cout<<r[i][1]<<","<<r[i][2]<<"->";}cout<<n<<","<<m<<endl;
} //向r数组下标为k的那一行,记录x,y点 
void dfs(int x,int y,int k){//记录坐标 r[k][1] = x;r[k][2] = y;//如果走到了终点,打印路径if(x == n && y == m){print(k);//停止递归函数,到了终点打印,就不需要继续递归了return; } int tx,ty;for(int i = 1;i <= 2;i++){tx = x + fx[i];ty = y + fy[i];//判断tx,ty有效if(tx>=1&&tx<=n&&ty>=1&&ty<=m){dfs(tx,ty,k+1);} }
} int main(){cin>>n>>m; //向r数组下标为1的那一行,记录1,1点 dfs(1,1,1);
}

//解法一:参照迷宫的第一条路,深搜出迷宫的所有路径#include <bits/stdc++.h>
using namespace std;
//只能向下或者向右走:优先向下,其次向右 
int n,m;
int r[20][3];//存储行走路径 
//方向的变化 
int fx[3] = {0,1,0};
int fy[3] = {0,0,1}; 
int c;//计数器 void print(int k){c++;cout<<c<<":";//除了最后一个点以外 for(int i = 1;i < k;i++){cout<<r[i][1]<<","<<r[i][2]<<"->";}cout<<n<<","<<m<<endl;
} //向r数组下标为k的那一行,记录x,y点 
void dfs(int x,int y,int k){//记录坐标 r[k][1] = x;r[k][2] = y;//如果走到了终点,打印路径if(x == n && y == m){print(k);//停止递归函数,到了终点打印,就不需要继续递归了return; } int tx,ty;for(int i = 1;i <= 2;i++){tx = x + fx[i];ty = y + fy[i];//判断tx,ty有效if(tx>=1&&tx<=n&&ty>=1&&ty<=m){dfs(tx,ty,k+1);} }
} int main(){cin>>n>>m; //向r数组下标为1的那一行,记录1,1点 dfs(1,1,1);
}

来源

深搜 递归

 

这篇关于东方博宜OJ 【基础】卒的遍历的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/245203

相关文章

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

从基础到进阶详解Pandas时间数据处理指南

《从基础到进阶详解Pandas时间数据处理指南》Pandas构建了完整的时间数据处理生态,核心由四个基础类构成,Timestamp,DatetimeIndex,Period和Timedelta,下面我... 目录1. 时间数据类型与基础操作1.1 核心时间对象体系1.2 时间数据生成技巧2. 时间索引与数据

安装centos8设置基础软件仓库时出错的解决方案

《安装centos8设置基础软件仓库时出错的解决方案》:本文主要介绍安装centos8设置基础软件仓库时出错的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录安装Centos8设置基础软件仓库时出错版本 8版本 8.2.200android4版本 javas

Linux基础命令@grep、wc、管道符的使用详解

《Linux基础命令@grep、wc、管道符的使用详解》:本文主要介绍Linux基础命令@grep、wc、管道符的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录grep概念语法作用演示一演示二演示三,带选项 -nwc概念语法作用wc,不带选项-c,统计字节数-

python操作redis基础

《python操作redis基础》Redis(RemoteDictionaryServer)是一个开源的、基于内存的键值对(Key-Value)存储系统,它通常用作数据库、缓存和消息代理,这篇文章... 目录1. Redis 简介2. 前提条件3. 安装 python Redis 客户端库4. 连接到 Re

python进行while遍历的常见错误解析

《python进行while遍历的常见错误解析》在Python中选择合适的遍历方式需要综合考虑可读性、性能和具体需求,本文就来和大家讲解一下python中while遍历常见错误以及所有遍历方法的优缺点... 目录一、超出数组范围问题分析错误复现解决方法关键区别二、continue使用问题分析正确写法关键点三

SpringBoot基础框架详解

《SpringBoot基础框架详解》SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等,使用SpringBoot可以不用或者只需要很少的Spring配置就可以让企业项目快... 目录SpringBoot基础 – 框架介绍1.SpringBoot介绍1.1 概述1.2 核心功能2

Spring Boot集成SLF4j从基础到高级实践(最新推荐)

《SpringBoot集成SLF4j从基础到高级实践(最新推荐)》SLF4j(SimpleLoggingFacadeforJava)是一个日志门面(Facade),不是具体的日志实现,这篇文章主要介... 目录一、日志框架概述与SLF4j简介1.1 为什么需要日志框架1.2 主流日志框架对比1.3 SLF4

Spring Boot集成Logback终极指南之从基础到高级配置实战指南

《SpringBoot集成Logback终极指南之从基础到高级配置实战指南》Logback是一个可靠、通用且快速的Java日志框架,作为Log4j的继承者,由Log4j创始人设计,:本文主要介绍... 目录一、Logback简介与Spring Boot集成基础1.1 Logback是什么?1.2 Sprin

Java遍历HashMap的6种常见方式

《Java遍历HashMap的6种常见方式》这篇文章主要给大家介绍了关于Java遍历HashMap的6种常见方式,方法包括使用keySet()、entrySet()、forEach()、迭代器以及分别... 目录1,使用 keySet() 遍历键,再通过键获取值2,使用 entrySet() 遍历键值对3,