news 2026/4/16 12:05:40

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/4/16 12:04:40

Windows Cleaner实用指南:3步解决系统卡顿与空间不足问题

Windows Cleaner实用指南&#xff1a;3步解决系统卡顿与空间不足问题 【免费下载链接】WindowsCleaner Windows Cleaner——专治C盘爆红及各种不服&#xff01; 项目地址: https://gitcode.com/gh_mirrors/wi/WindowsCleaner 你是否经常遇到电脑运行缓慢、C盘空间告急的…

作者头像 李华
网站建设 2026/4/15 12:19:38

PyTorch学习率调度器选择与GPU训练效果关系

PyTorch学习率调度器选择与GPU训练效果关系 在深度学习的实际项目中&#xff0c;我们常常会遇到这样的问题&#xff1a;模型刚开始训练时损失下降很快&#xff0c;但到了后期却开始震荡甚至发散&#xff1b;或者整个训练过程异常缓慢&#xff0c;明明用了高端GPU&#xff0c;效…

作者头像 李华
网站建设 2026/4/11 17:14:38

5分钟快速上手AlwaysOnTop:Windows窗口置顶终极指南

5分钟快速上手AlwaysOnTop&#xff1a;Windows窗口置顶终极指南 【免费下载链接】AlwaysOnTop Make a Windows application always run on top 项目地址: https://gitcode.com/gh_mirrors/al/AlwaysOnTop 还在为频繁切换窗口而降低工作效率烦恼吗&#xff1f;AlwaysOnTo…

作者头像 李华
网站建设 2026/4/15 18:27:04

NVIDIA Profile Inspector终极指南:快速解锁显卡隐藏性能

NVIDIA Profile Inspector终极指南&#xff1a;快速解锁显卡隐藏性能 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector 你的显卡真的在全力工作吗&#xff1f;为什么同样的配置&#xff0c;别人的游戏画面…

作者头像 李华
网站建设 2026/4/13 14:27:13

PyTorch梯度裁剪防止爆炸(GPU训练稳定性提升)

PyTorch梯度裁剪与GPU训练稳定性优化实践 在深度学习模型日益复杂的今天&#xff0c;尤其是面对Transformer、RNN等深层网络结构时&#xff0c;一个看似微小的数值问题——梯度爆炸&#xff0c;常常成为压垮训练进程的最后一根稻草。你是否经历过这样的场景&#xff1a;前几轮训…

作者头像 李华
网站建设 2026/4/11 21:22:26

CefFlashBrowser:轻松突破网站限制的自定义版本Flash浏览器

还在为无法访问老网站上的Flash内容而烦恼吗&#xff1f;CefFlashBrowser是一款专为解决Flash内容访问难题而设计的浏览器&#xff0c;它独特的自定义版本伪装功能&#xff0c;让你轻松绕过网站的Flash版本检测&#xff0c;重新畅游那些珍贵的Flash资源世界。 【免费下载链接】…

作者头像 李华