东方博宜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

相关文章

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键

mysql的基础语句和外键查询及其语句详解(推荐)

《mysql的基础语句和外键查询及其语句详解(推荐)》:本文主要介绍mysql的基础语句和外键查询及其语句详解(推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录一、mysql 基础语句1. 数据库操作 创建数据库2. 表操作 创建表3. CRUD 操作二、外键

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

Python基础文件操作方法超详细讲解(详解版)

《Python基础文件操作方法超详细讲解(详解版)》文件就是操作系统为用户或应用程序提供的一个读写硬盘的虚拟单位,文件的核心操作就是读和写,:本文主要介绍Python基础文件操作方法超详细讲解的相... 目录一、文件操作1. 文件打开与关闭1.1 打开文件1.2 关闭文件2. 访问模式及说明二、文件读写1.

C#基础之委托详解(Delegate)

《C#基础之委托详解(Delegate)》:本文主要介绍C#基础之委托(Delegate),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 委托定义2. 委托实例化3. 多播委托(Multicast Delegates)4. 委托的用途事件处理回调函数LINQ

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

C++中使用vector存储并遍历数据的基本步骤

《C++中使用vector存储并遍历数据的基本步骤》C++标准模板库(STL)提供了多种容器类型,包括顺序容器、关联容器、无序关联容器和容器适配器,每种容器都有其特定的用途和特性,:本文主要介绍C... 目录(1)容器及简要描述‌php顺序容器‌‌关联容器‌‌无序关联容器‌(基于哈希表):‌容器适配器‌:(

MySQL中my.ini文件的基础配置和优化配置方式

《MySQL中my.ini文件的基础配置和优化配置方式》文章讨论了数据库异步同步的优化思路,包括三个主要方面:幂等性、时序和延迟,作者还分享了MySQL配置文件的优化经验,并鼓励读者提供支持... 目录mysql my.ini文件的配置和优化配置优化思路MySQL配置文件优化总结MySQL my.ini文件

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念