leetcode 756(枚举可填字母)

756: 金字塔转换矩阵

基于bottom构造"金字塔"型矩阵

复制代码
int n=bottom.size();
vector<string> pyramid(n);
for(int i=0;i<n-1;i++) pyramid[i].resize(i+1);
pyramid[n-1]=move(bottom);

为了快速知道 AA→[B,C] 的对应关系,可以把 allowed 用哈希表(或者二维数组)分组,把 allowed[i] 前两个字母对应的第三个字母,记录在一个列表中,方便后续遍历。

复制代码
string base[6][6]; //三角形底部两个字母 -> [三角形顶部字母]
for(auto& a:allowed) base[a[0]-'A'][a[1]-'A']+=a[2];

优化:减少重复搜索(剪枝)

复制代码
class Solution {
public:
    bool pyramidTransition(string bottom, vector<string>& allowed) {
        string base[6][6]; //三角形底部两个字母 -> [三角形顶部字母]
        for(auto& a:allowed) base[a[0]-'A'][a[1]-'A']+=a[2];
        int n=bottom.size();
        vector<string> pyramid(n);
        for(int i=0;i<n-1;i++) pyramid[i].resize(i+1);
        pyramid[n-1]=move(bottom);

        unordered_set<string> vis; //访问标记

        //现在准备填(i,j)这个格子,返回能否填完所有格子(从下往上填,每行从左到右填)
        auto dfs=[&](this auto&& dfs,int i,int j)->bool{
            if(i<0) return true; //所有格子都已填完
            if(j==i+1){
                if(!vis.insert(pyramid[i]).second) return false;
                return dfs(i-1,0); 
            }
            //枚举(i,j)填什么字母,这取决于(i+1,j)和(i+1,j+1)填的字母
            for(char top:base[pyramid[i+1][j]-'A'][pyramid[i+1][j+1]-'A']){
                pyramid[i][j]=top; //遍历已知底下两个字母时上方allowed的字母(base中)
                if(dfs(i,j+1)) return true;
            }
            return false;
        };
        //从倒数第二行开始填
        return dfs(n-2,0);
    }
};
相关推荐
Jeremy爱编码2 小时前
leetcode热题子集
算法·leetcode·职场和发展
csg11072 小时前
LORA网络的“最后一公里”难题:当信号被重重阻挡,我们有哪些“方法”来增强覆盖?
单片机·嵌入式硬件·物联网·算法
brave and determined2 小时前
传感器学习(day18):智能手机3D结构光:解锁未来的第三只眼
嵌入式硬件·算法·3d·智能手机·tof·嵌入式设计·3d结构光
CoovallyAIHub2 小时前
当小龙虾算法遇上YOLO:如何提升太阳能电池缺陷检测精度?
深度学习·算法·计算机视觉
Tisfy2 小时前
LeetCode 756.金字塔转换矩阵:深度优先搜索
leetcode·矩阵·深度优先
努力学算法的蒟蒻2 小时前
day48(12.29)——leetcode面试经典150
算法·leetcode·面试
CoovallyAIHub2 小时前
AI如何精准关联照片与抽象平面图?C3数据集迈向3D视觉多模态
深度学习·算法·计算机视觉
GEO AI搜索优化助手2 小时前
数据共振:GEO与SEO的算法协同与智能决策系统
人工智能·算法·搜索引擎·生成式引擎优化·ai优化·geo搜索优化
java修仙传2 小时前
力扣hot100:有效的括号
算法·leetcode·职场和发展