日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪(fǎng)問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

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

發(fā)布時(shí)間:2024/7/5 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 剑指Offer - 面试题13. 机器人的运动范围(BFS/DFS) 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

文章目錄

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

1. 題目

地上有一個(gè)m行n列的方格,從坐標(biāo) [0,0] 到坐標(biāo) [m-1,n-1] 。一個(gè)機(jī)器人從坐標(biāo) [0, 0] 的格子開(kāi)始移動(dòng),它每次可以向左、右、上、下移動(dòng)一格(不能移動(dòng)到方格外),也不能進(jìn)入行坐標(biāo)和列坐標(biāo)的數(shù)位之和大于k的格子。例如,當(dāng)k為18時(shí),機(jī)器人能夠進(jìn)入方格 [35, 37] ,因?yàn)?+5+3+7=18。但它不能進(jìn)入方格 [35, 37],因?yàn)?+5+3+8=19。請(qǐng)問(wèn)該機(jī)器人能夠到達(dá)多少個(gè)格子?

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

來(lái)源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/ji-qi-ren-de-yun-dong-fan-wei-lcof
著作權(quán)歸領(lǐng)扣網(wǎng)絡(luò)所有。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系官方授權(quán),非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。

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

總結(jié)

以上是生活随笔為你收集整理的剑指Offer - 面试题13. 机器人的运动范围(BFS/DFS)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。