news 2026/2/9 9:46:45

leetcode 756(枚举可填字母)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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); } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/6 6:01:54

[C++][正则表达式]常用C++正则表达式用法

匹配字符串是否包含某些字符&#xff0c;可以使用regex_match&#xff0c;但是这个是全字匹配&#xff0c;不能部分匹配&#xff0c;比如代码语言&#xff1a;javascriptAI代码解释using namespace std; int main() {std::string str "1234";std::regex reg("\…

作者头像 李华
网站建设 2026/2/5 6:09:43

零基础也能懂:LED灯基本参数解读指南

零基础也能懂&#xff1a;LED灯基本参数解读指南你有没有过这样的经历&#xff1f;走进灯具店&#xff0c;面对琳琅满目的LED灯泡&#xff0c;包装上写着“超亮800流明”、“6500K冷白光”、“显色指数Ra>90”&#xff0c;看得一头雾水。导购员说&#xff1a;“这个好&#…

作者头像 李华
网站建设 2026/2/5 18:58:06

PyTorch模型推理延迟高?尝试CUDA核心优化策略

PyTorch模型推理延迟高&#xff1f;尝试CUDA核心优化策略 在当前AI系统对实时性要求越来越高的背景下&#xff0c;一个看似训练完成的深度学习模型&#xff0c;在实际部署中却“跑不起来”——推理延迟居高不下、吞吐量上不去&#xff0c;这种场景并不少见。尤其是在视频流分析…

作者头像 李华
网站建设 2026/2/6 20:44:13

3分钟轻松搞定GitHub界面汉化:零基础浏览器插件完美方案

3分钟轻松搞定GitHub界面汉化&#xff1a;零基础浏览器插件完美方案 【免费下载链接】github-chinese GitHub 汉化插件&#xff0c;GitHub 中文化界面。 (GitHub Translation To Chinese) 项目地址: https://gitcode.com/gh_mirrors/gi/github-chinese 还在为GitHub英文…

作者头像 李华
网站建设 2026/2/7 2:44:11

Windows 11远程桌面多用户终极突破:RDP Wrapper完全解锁指南

Windows 11远程桌面多用户终极突破&#xff1a;RDP Wrapper完全解锁指南 【免费下载链接】rdpwrap RDP Wrapper Library 项目地址: https://gitcode.com/gh_mirrors/rd/rdpwrap 还在为Windows 11系统只能单用户远程访问而束手无策&#xff1f;想象一下这样的场景&#x…

作者头像 李华
网站建设 2026/2/4 17:04:36

PyTorch Hook机制用于梯度监控(GPU模式适用)

PyTorch Hook机制用于梯度监控&#xff08;GPU模式适用&#xff09; 在深度学习模型日益复杂的今天&#xff0c;训练过程中的“黑箱”问题愈发突出。尤其是在使用Transformer、ResNet等深层网络时&#xff0c;我们常常面临这样的困惑&#xff1a;为什么模型收敛缓慢&#xff1f…

作者头像 李华