随笔 - 165,  文章 - 0,  评论 - 4,  阅读 - 18023

题目:

class Solution {
public:
    int m, n, cnt, res=0;
    int digit(int n){
        int sum = 0;
        while(n){
            sum += n%10;
            n/=10;
        }
        return sum;
    }
    void traversal(int i, int j, vector<vector<bool>>& used){
        if(i>=m||j>=n||digit(i)+digit(j)>cnt||used[i][j]) return;
        res++;
        used[i][j]=true;
        traversal(i+1, j, used);
        traversal(i, j+1, used);
    }
    int wardrobeFinishing(int m, int n, int cnt) {
        this->m = m;
        this->n = n;
        this->cnt = cnt;
        vector<vector<bool>> used(m, vector<bool>(n, false));
        traversal(0, 0, used);
        return res;
    }
};
class Solution {          //本题的思路为递归法
public:
    int cal(int i){       //先写个计算位数和的函数cal
        int sum = 0;
        while(i){
            sum+=i%10;
            i/=10;
        }
        return sum;
    }
    void traversal(int i, int j, int m, int n, int k, int& result, vector<vector<bool>>& visited){   //注意递归传入的参数有点多,顺序不要乱。result和visited必须要有&引用符号
        if(i<0||j<0||i>=m||j>=n||cal(i)+cal(j) > k||visited[i][j]) return;      //递归终止条件,也就是走到了不符合条件的格子:1.超出边界 2.位数和大于k 3.格子已经被访问过
        visited[i][j] = true;                        //该格子符合条件,标记为true
        result++;                                    //结果+1
        traversal(i+1, j, m, n, k, result, visited); //按照四个方向进行递归
        traversal(i-1, j, m, n, k, result, visited);
        traversal(i, j+1, m, n, k, result, visited);
        traversal(i, j-1, m, n, k, result, visited);
    }
    int movingCount(int m, int n, int k) {
        int result = 0;       //初始化result
        vector<vector<bool>> visited(m, vector<bool>(n, false));  //初始化visited标记矩阵
        traversal(0, 0, m, n, k, result, visited);
        return result;
    }
};
posted on   孜孜不倦fly  阅读(5)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示