剑指offer第11题:机器人运动范围
时间:2022-07-22
本文章向大家介绍剑指offer第11题:机器人运动范围,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
机器人运动范围
剑指Offer 13:机器人的运动范围 【中等】”
题目描述
方法:
此方法我们可以直接按照题目中的要求,将所有的方格全都访问一遍,由于所有的格子需要满足一个条件,连续性和单元格的坐标和小于n即可。
我们使用==递归==的方式进行完成。首先我们自己来初始化一个boolen[][]
矩阵,用来标记每一个方格是否可达。如果当前方格(i,j)
可达,我们继续向下和向右遍历,如果当前方格(i,j)
不可达,那么我们则不再需要继续向后递归。
当我们完成整个方格的标记之后,我们遍历存放可达的boolean
矩阵,然后进行统计可达的个数就好了~
代码实现:
class Solution {
public int movingCount(int m, int n, int k) {
boolean[][] flag = new boolean[m][n];//记录访问了哪些格子
extend(flag , 0 , 0 , m , n , k);
int res = 0;
for(int i = 0 ; i < m ; i++){
for(int j = 0 ; j < n ; j++){
if(!flag[i][j]) continue;//如果当前的格子已经遍历过了,则不再进行遍历了
res++;
}
}
return res;
}
private void extend (boolean[][] flag , int row , int col , int m , int n , int k){
//判断当前格子是否已经超出范围并且确保没有被访问过
if(row < 0 || row >= m || col < 0 || col >= n || flag[row][col]) return;
int sum = 0 ;
int i = row , j = col ;
while(row > 0 || col > 0){
sum += row%10 + col%10;
row /= 10;
col /= 10;
}
if(sum > k) return; //判断是否可达
flag[i][j] = true;
//我们规定机器人都是从左上角开始移动的,所以我们只需要让机器人向右或者向下即可
extend(flag , i+1 , j , m , n , k);//向下
extend(flag , i , j+1 , m , n , k);//向右
}
}
【思考】
此题的解题思路是比较明显的,就是递归思想,在很多题解里面所说的DFS
其实本质上也是一种递归的表现形式,首先弄清楚何时递归,何时不可递归,以及每次递归时我们需要的处理即可。大致可以从这道题目中略见一二。
- hql中setDate和setTimeStamp的区别
- Spring源码解析——如何阅读源码
- java获取当前时间和前一天日期
- 国内首个二代基因测序 FPGA 加速方案-背后的技术
- Java基础04 封装与接口
- Maven那点事儿(Eclipse版)
- 【Spring开发】—— Spring注入静态变量
- java判断list为空
- Java基础01 从HelloWorld到面向对象
- Java基础02 方法与数据成员
- 【Spring实战】—— 13 AspectJ注解切面
- EasyUI日期选择框
- Java基础03 构造器与方法重载
- web.xml is missing and <failOnMissingWebXml> is set to true
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Python测试开发django5.urls.py参数name与<a>标签的引用
- Pytest配置文件pytest.ini
- 移植uc/OS-III最新版到小熊派开发板(STM32L431)
- phpStudy默认配置致Nginx解析漏洞复现
- HW|蓝队实战溯源反制手册分享
- 工具开发|Burp插件Unexpected_information
- 爱了!安利一个相见恨晚的可视化学习网站
- pandas+PyQt5轻松制作数据处理工具
- Python高效编程之88条军规(1):编码规范、字节序列与字符串
- 这是一份 pip 常用命令小结~
- 太震撼了,我用python画出全北京的公交线路动图
- 小伙Python爬虫并自制新闻网站,太好玩了
- TRTC Android端开发接入学习之视频会议(八)
- MySQL锁都分不清,怎么面试进大厂?
- Kubernetes Controller高可用诡异的15mins超时