IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> LeetCode 6059. 检查是否有合法括号字符串路径(BFS) -> 正文阅读

[数据结构与算法]LeetCode 6059. 检查是否有合法括号字符串路径(BFS)

文章目录

1. 题目

一个括号字符串是一个 非空 且只包含 '('')' 的字符串。
如果下面 任意 条件为 真 ,那么这个括号字符串就是 合法的 。

  • 字符串是 ()
  • 字符串可以表示为 AB(A 连接 B),A 和 B 都是合法括号序列。
  • 字符串可以表示为 (A) ,其中 A 是合法括号序列。

给你一个 m x n 的括号网格图矩阵 grid 。
网格图中一个 合法括号路径 是满足以下所有条件的一条路径:

  • 路径开始于左上角格子 (0, 0)
  • 路径结束于右下角格子 (m - 1, n - 1)
  • 路径每次只会向 或者向 移动。
  • 路径经过的格子组成的括号字符串是 合法 的。

如果网格图中存在一条 合法括号路径 ,请返回 true ,否则返回 false 。

示例 1:
输入:grid = [["(","(","("],[")","(",")"],["(","(",")"],["(","(",")"]]
输出:true
解释:上图展示了两条路径,它们都是合法括号字符串路径。
第一条路径得到的合法字符串是 "()(())" 。
第二条路径得到的合法字符串是 "((()))" 。
注意可能有其他的合法括号字符串路径。

示例 2:
输入:grid = [[")",")"],["(","("]]
输出:false
解释:两条可行路径分别得到 "))("")((" 。由于它们都不是合法括号字符串,我们返回 false 。
 
提示:
m == grid.length
n == grid[i].length
1 <= m, n <= 100
grid[i][j] 要么是 '(' ,要么是 ')'

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/check-if-there-is-a-valid-parentheses-string-path
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • 使用队列进行广度优先搜索
  • 队列里存储 { 待配对的左括号个数,位置信息x, y },将3个值编码成一个 int
class Solution {
public:
    bool hasValidPath(vector<vector<char>>& grid) {
        int dd = 128*128, d = 128, m = grid.size(), n = grid[0].size();
        if(grid[0][0]!='(' || grid[m-1][n-1]!=')') return false;
        vector<vector<int>> dir = {{0, 1}, {1, 0}};
        queue<int> q;
        unordered_set<int> vis;
        q.push(dd);  // 起点的编码:左括号个数*128*128 + x*128 + y
        vis.insert(dd);
        while(!q.empty())
        {
            auto tp = q.front();
            q.pop();
            int left = tp/dd;
            int x = tp%dd/d, y = tp%d;
            if(x==m-1 && y==n-1 && left==0) return true;
            for(int k = 0; k < 2; ++k)
            {
                int nx = x + dir[k][0], ny = y + dir[k][1];
                if(nx>=0 && nx<m && ny>=0 && ny<n)
                {
                    if(grid[nx][ny]=='(')
                    {
                        int hash = (left+1)*dd+(nx*d+ny);
                        if(!vis.count(hash) && left+1 <= (m-1-nx+n-1-ny))
                        {
                            q.push(hash);
                            vis.insert(hash);
                        }
                    }
                    else
                    {
                        if(left-1 < 0)  // 不能配对
                            continue;
                        int hash = (left-1)*dd+(nx*d+ny);
                        if(!vis.count(hash) && left-1 <= (m-1-nx+n-1-ny))
                        {
                            q.push(hash);
                            vis.insert(hash);
                        }
                    }
                }
            }
        }
        return false;
    }
};

1556 ms 282.6 MB C++


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
Michael阿明

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-05-14 10:09:04  更:2022-05-14 10:10:50 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/1 22:59:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码