day80(2.8)——leetcode面试经典150

22. 括号生成

22. 括号生成

题目:

题解:

java 复制代码
class Solution {
    int left;   //左括号
    int right;  //右括号
    List<String> res;
    void dfs(int l, int r, StringBuilder sb) {
        if(l==0&&r==0) {
            res.add(sb.toString());
            return ;
        }
        if(l>0) {
            sb.append('(');
            dfs(l-1, r, sb);
            sb.deleteCharAt(sb.length()-1);
        }
        //剩余的左括号也要少于右括号才能形成完整的括号
        if(r>0&&l<r) {
            sb.append(')');
            dfs(l, r-1, sb);
            sb.deleteCharAt(sb.length()-1);
        }
    }

    public List<String> generateParenthesis(int n) {
        left=n;
        right=n;
        res = new ArrayList<>();
        dfs(left, right, new StringBuilder());
        return res;    
    }
}

79. 单词搜索

79. 单词搜索

题目:

题解:

java 复制代码
class Solution {
    int n;
    int m;
    boolean[][] visited;

    boolean dfs(int x, int y, char[][] board, String word, int t) {
         // 先检查是否越界或已访问
        if (x < 0 || x >= n || y < 0 || y >= m || visited[x][y]) {
            return false;
        }
        
        // 检查当前字符是否匹配
        if (board[x][y] != word.charAt(t)) {
            return false;
        }
        // 如果已经匹配到最后一个字符
        if(t==word.length()-1) {
            return true; 
        }
        visited[x][y]=true;
         // 向四个方向搜索(注意:题目只允许上下左右,不是8个方向!)
        boolean found = 
            dfs(x + 1, y, board, word, t + 1) ||
            dfs(x - 1, y, board, word, t + 1) ||
            dfs(x, y + 1, board, word, t + 1) ||
            dfs(x, y - 1, board, word, t + 1);

        //恢复现场
        visited[x][y]=false;

        return found;
    }

    public boolean exist(char[][] board, String word) {
        n = board.length;
        m = board[0].length;
        visited = new boolean[n][m];
        for(int i=0;i<n;i++) {
            for(int j=0;j<m;j++) {
                if(board[i][j]==word.charAt(0)) {
                    if(dfs(i, j, board, word, 0)) {
                        return true;
                    }
                }
            }
        }
        return false;
    }
}
相关推荐
语戚1 小时前
力扣 3161. 块放置查询:线段树解法(Java 实现)
java·算法·leetcode·面试·线段树·力扣·
天天进步20152 小时前
Python全栈项目实战:从零构建校园心理健康咨询平台
面试·职场和发展
武子康3 小时前
调查研究-151 Slack vs Jira:区别、使用指南与团队选择方法
人工智能·科技·深度学习·ai·职场和发展·jira·slack
JAVA社区3 小时前
Java高级全套教程(十一)—— Kubernetes 超详细企业级实战详解
java·运维·微服务·容器·面试·kubernetes
kyriewen4 小时前
大厂面试新规:不会用AI编程,直接挂
前端·面试·ai编程
努力找实习的前端小白4 小时前
useImperativeHandle,useRef,forwardRef的协作关系
前端·面试
胡萝卜术5 小时前
从零搭建生成式AI项目:OpenAI + Node.js 环境配置与密钥安全实践
前端·javascript·面试
苏三的开发日记5 小时前
Spring Boot启动慢如何优化
面试·编程语言
神奇小汤圆6 小时前
125K+ star 的 AI 爬虫神器:让你的 Agent 秒变网络达人
面试
凯瑟琳.奥古斯特8 小时前
力扣1235:加权区间调度最优解
java·python·算法·leetcode·职场和发展