news 2026/6/10 14:41:44

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/6/9 15:38:44

Jupyter Lab整合PyTorch:交互式编程提升开发效率

Jupyter Lab整合PyTorch&#xff1a;交互式编程提升开发效率 在深度学习项目中&#xff0c;你是否曾因环境配置失败而浪费一整天&#xff1f;是否在调试模型时反复重启脚本&#xff0c;只为查看一个中间输出&#xff1f;又或者&#xff0c;在团队协作中因为“在我机器上能跑”这…

作者头像 李华
网站建设 2026/6/7 7:26:21

Docker Volume持久化存储PyTorch训练结果

Docker Volume 持久化存储 PyTorch 训练结果 在深度学习项目中&#xff0c;一次完整的模型训练往往需要数小时甚至数天。当 GPU 正在全力运行、显存占用接近极限时&#xff0c;最怕的不是性能瓶颈&#xff0c;而是——容器一删&#xff0c;所有训练成果灰飞烟灭。 这并非危言耸…

作者头像 李华
网站建设 2026/6/10 1:08:15

使用Logrotate管理PyTorch长时间训练日志

使用 Logrotate 管理 PyTorch 长时间训练日志 在深度学习项目中&#xff0c;一个看似不起眼却常常引发严重后果的问题是&#xff1a;日志文件失控增长。你是否经历过这样的场景&#xff1f;某次长达数天的模型训练任务正在进行&#xff0c;GPU 利用率稳定、损失曲线平滑下降——…

作者头像 李华
网站建设 2026/6/7 21:16:27

新手教程:手把手学习PCB设计规则基础内容

新手也能懂的PCB设计规则实战指南&#xff1a;从“连通就行”到“一次成功”你有没有过这样的经历&#xff1f;辛辛苦苦画完一块板子&#xff0c;原理图检查了三遍&#xff0c;元器件也排布得整整齐齐&#xff0c;结果一上电——MCU不启动、ADC读数跳来跳去&#xff0c;甚至电源…

作者头像 李华
网站建设 2026/6/10 10:28:50

Docker镜像瘦身技巧:减小PyTorch-CUDA体积

Docker镜像瘦身技巧&#xff1a;减小PyTorch-CUDA体积 在AI模型部署的日常中&#xff0c;你是否经历过这样的场景&#xff1a;CI流水线卡在“拉取镜像”阶段长达数分钟&#xff1f;Kubernetes集群因节点存储不足而拒绝调度新Pod&#xff1f;或者边缘设备上一次镜像推送耗时超过…

作者头像 李华
网站建设 2026/6/10 11:42:27

Zotero GPT完整使用教程:5步实现文献智能管理

还在为海量学术文献整理而头疼&#xff1f;Zotero GPT插件将彻底改变你的研究方式&#xff01;这款创新工具将OpenAI的强大AI能力无缝集成到Zotero文献管理系统中&#xff0c;让你在5分钟内就能体验到智能文献处理的便利。无论你是学生、研究人员还是学术工作者&#xff0c;这款…

作者头像 李华