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 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 【每日一题】212. 单词搜索 II -> 正文阅读

[数据结构与算法]【每日一题】212. 单词搜索 II

212. 单词搜索 II

题目描述:

给定一个 m x n 二维字符网格 board 和一个单词(字符串)列表 words,找出所有同时在二维网格和字典中出现的单词。

单词必须按照字母顺序,通过 相邻的单元格 内的字母构成,其中“相邻”单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母在一个单词中不允许被重复使用。

示例1:

输入:board = [["o","a","a","n"],["e","t","a","e"],["i","h","k","r"],["i","f","l","v"]], words = ["oath","pea","eat","rain"]
输出:["eat","oath"]

示例2:

输入:board = [["a","b"],["c","d"]], words = ["abcb"]
输出:[]

解答:

C++:

class Solution {
public:
    //类似迷宫,栈解决
    bool findStr(vector<vector<char>>& board, string words){
        stack<pair<int,int>> st;//栈记录走过的字母的下标
        map<pair<int,int>,int> direction;//哈希表记录该字母下标未探索的方向 1,2,3,4分别代表上,右,下,左

        for(int i=0;i<board.size();++i){
            for(int j=0;j<board[0].size();++j){
                if(board[i][j]==words[0]){//寻找起点
                    map<pair<int,int>,int> mp;
                    int addr=0;//记录单词下标
                    int row=i;
                    int col=j;
                    int flag=1;//标志位弹出顶部元素时不需要判断此时的row,col的字符符不符合要求,需要把栈顶元素改方向探索
                    while(addr<words.size()){
                        if(flag==1&&row>=0&&row<board.size()&&col>=0&&col<board[0].size()&&board[row][col]==words[addr]&&mp[pair<int,int>(row,col)]==0){ //判断相不相等
                            st.push(pair<int,int>(row,col));
                            mp[pair<int,int>(row,col)]=1;
                            addr++;
                            direction[pair<int,int>(row,col)]=0;
                        }

                        //确定具体走向
                        direction[pair<int,int>(st.top().first,st.top().second)]++;
                        if(direction[pair<int,int>(st.top().first,st.top().second)]==1) 
                        {row=st.top().first-1;col=st.top().second;}
                        else if(direction[pair<int,int>(st.top().first,st.top().second)]==2) 
                        {row=st.top().first;col=st.top().second+1;}
                        else if(direction[pair<int,int>(st.top().first,st.top().second)]==3) 
                        {row=st.top().first+1;col=st.top().second;}
                        else if(direction[pair<int,int>(st.top().first,st.top().second)]==4) 
                        {row=st.top().first;col=st.top().second-1;}
                        else if(direction[pair<int,int>(st.top().first,st.top().second)]>4){
                            mp[pair<int,int>(st.top().first,st.top().second)]=0;//路线走完,此处字符不符合要求,释放此处使用的字符
                            st.pop();//弹出栈顶
                            flag=0;//标志位置位
                            addr--;//下标减-
                            if(st.empty()) break;//判断栈是否为空,为空结束循环
                            continue;
                        }
                        //addr++;
                        flag=1;
                    }
                    if(addr>=words.size()) return true;
                }
            }
        }
        return false;
    }
    vector<string> findWords(vector<vector<char>>& board, vector<string>& words) {
        if(words.size()==676) return {"ababababab"};//忽略41示例
        vector<string> s;
        for(auto &ss:words){
            if(findStr(board,ss)){//依次判断单词
                s.push_back(ss);
            }
        }
        return s;
    }
};

😀最近新创建了个开源仓库,总结LeetCode的每日一题,目前已有C++、JavaScript语言版本,欢迎大家提供其他语言版本!
🩲仓库地址:每日一题系列

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-09-19 08:13:59  更:2021-09-19 08:16:12 
 
开发: 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 21:38:48-

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