文章目录

  • 1. 题目
  • 2. 解题
    • 2.1 BFS
    • 2.2 DFS

1. 题目

地上有一个m行n列的方格,从坐标 [0,0] 到坐标 [m-1,n-1] 。一个机器人从坐标 [0, 0] 的格子开始移动,它每次可以向左、右、上、下移动一格(不能移动到方格外),也不能进入行坐标和列坐标的数位之和大于k的格子。例如,当k为18时,机器人能够进入方格 [35, 37] ,因为3+5+3+7=18。但它不能进入方格 [35, 37],因为3+5+3+8=19。请问该机器人能够到达多少个格子?

示例 1:
输入:m = 2, n = 3, k = 1
输出:3示例 1:
输入:m = 3, n = 1, k = 0
输出:1提示:
1 <= n,m <= 100
0 <= k <= 20

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/ji-qi-ren-de-yun-dong-fan-wei-lcof
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

2.1 BFS

class Solution {public:int movingCount(int m, int n, int k) {vector<vector<bool>> visited(m, vector<bool>(n,false));vector<vector<int>> dir = {{-1,0},{1,0},{0,1},{0,-1}};queue<vector<int>> q;q.push({0,0});visited[0][0] = true;int count = 1, tpx, tpy, x, y, i;while(!q.empty()){tpx = q.front()[0];tpy = q.front()[1];q.pop();for(i = 0; i < 4; ++i){x = tpx+dir[i][0];y = tpy+dir[i][1];if(x>=0 && x<m && y>=0 && y<n && !visited[x][y] && valid(x,y,k)){q.push({x,y});visited[x][y] = true;count++;}}          }return count;}bool valid(int x, int y, int &k){int sum = 0;while(x){sum += (x%10);x /= 10;}while(y){sum += (y%10);y /= 10;}return (sum<=k);}
};

2.2 DFS

class Solution {vector<vector<int>> dir = {{-1,0},{1,0},{0,1},{0,-1}};
public:int movingCount(int m, int n, int k) {vector<vector<bool>> visited(m, vector<bool>(n,false));int count = 1;visited[0][0] = true;dfs(0,0,count,visited,m,n,k);return count;}void dfs(int i, int j, int& count, vector<vector<bool>>& visited,int& m, int& n, int& k){int x, y;for(int a = 0; a < 4; ++a){x = i+dir[a][0];y = j+dir[a][1];if(x >=0 && x<m && y>=0 && y<n && !visited[x][y] && valid(x,y,k)){visited[x][y] = true;count++;dfs(x,y,count,visited,m,n,k);}}}bool valid(int x, int y, int &k){int sum = 0;while(x){sum += (x%10);x /= 10;}while(y){sum += (y%10);y /= 10;}return (sum<=k);}
};

剑指Offer - 面试题13. 机器人的运动范围(BFS/DFS)相关推荐

  1. 【有返回值的回溯】剑指offer——面试题67——机器人的运动范围(回溯法)

    剑指offer--面试题67:机器人的运动范围(回溯法) Solution1: 此题和66题均是典型的回溯法题目,对比记忆思路! class Solution {public:int movingCo ...

  2. 剑指offer面试题13:O(1)删除链表结点

    面试题见剑指offer: struct ListNode { int value; ListNode *next; }; void DeleteNode(ListNode **pListHead,Li ...

  3. 剑指offer面试题13:机器人的运动范围

    题目描述:地上有一个m行n列的方格,从坐标 [0,0] 到坐标 [m-1,n-1] .一个机器人从坐标 [0, 0] 的格子开始移动,它每次可以向左.右.上.下移动一格(不能移动到方格外),也不能进入 ...

  4. [剑指offer]面试题13:在O(1)时间删除链表结点

    面试题13:在O(1)时间删除链表结点 题目:给定单向链表的头指针和一个结点指针,定义一个函数在 O(1)时间删除该结点.链表结点与函数的定义如下: struct ListNode {int valu ...

  5. 剑指offer面试题13扩展------Linus:利用二级指针删除单向链表

    Torvalds大婶:很多人不了解如何写核心底层代码 Torvalds大婶在slashdot上回答一些编程爱好者的提问,其中一个人问他什么样的代码是他所喜好的,大婶表述了自己一些观点之后,举了一个指针 ...

  6. 剑指Offer - 面试题12. 矩阵中的路径(DFS回溯)

    1. 题目 请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径.路径可以从矩阵中的任意一格开始,每一步可以在矩阵中向左.右.上.下移动一格.如果一条路径经过了矩阵的某一格,那么 ...

  7. 剑指offer 面试题三 找出数组中重复的数字

    1 import org.junit.Test; 2 3 import java.util.Arrays; 4 import java.util.HashSet; 5 6 public class D ...

  8. 剑指offer——面试题44:扑克牌顺子

    剑指offer--面试题44:扑克牌顺子 Solution1: 20180907重做 书上的思路. class Solution { public:bool IsContinuous(vector&l ...

  9. C++版 - 剑指offer 面试题39:判断平衡二叉树(LeetCode 110. Balanced Binary Tree) 题解

    剑指offer 面试题39:判断平衡二叉树 提交网址:  http://www.nowcoder.com/practice/8b3b95850edb4115918ecebdf1b4d222?tpId= ...

最新文章

  1. PyTorch 手把手搭建(MNIST)神经网络
  2. java定时器返回future_java 定时器线程池(ScheduledThreadPoolExecutor)的实现
  3. jQuery之文本框得失焦点
  4. $lookup做关联表查询
  5. android shape的用法总结
  6. 2020年上半年巨量引擎手机行业白皮书
  7. java-通过JDBC操作数据库
  8. 为什么越来越多的人喜欢自驾游?
  9. 电脑linux下载官网下载,Bluestar Linux
  10. android webview 设置cookie时间,解决Android webview设置cookie和cookie丢失的问题
  11. 引擎工具开发的一些总结
  12. 用FL Studio制作反向人声音效(Vocal Chops)
  13. stm32的rxcallback再debug界面显示没有编译,uC/OS-III
  14. 查看Xcode配置文件
  15. 矩阵基变换和坐标变换
  16. 计算机睡眠和休眠哪个好,休眠和睡眠哪个好?电脑休眠和睡眠有什么区别?
  17. 【python数据结构】多维数组
  18. SAC案例精选:SAC Planning实现SOP(销售与运营计划)模拟沙盘
  19. android安卓手机分屏多窗口实现方法
  20. Linkerd 2.9发布:全面支持mTLS与ARM!

热门文章

  1. 软件自动更新解决方案及QT实现
  2. 数据结构:单链表操作之如何判断链表是否带环及相关操作
  3. c++学习书籍推荐《超越C++标准库:Boost库导论》下载
  4. 魔戒(思维+bfs)
  5. Matplotlib从文件绘图时Y轴坐标不正确
  6. LA 3942 Remember the Word
  7. 自学python前戏
  8. day3-python学习笔记(三)字典、元组
  9. LeetCode | HouseCode 算法题
  10. Google Maps API 简易教程(四)