756. 金字塔转换矩阵

756. 金字塔转换矩阵


题目链接:756. 金字塔转换矩阵

代码如下:

cpp 复制代码
class Solution {
public:
	bool pyramidTransition(string bottom, vector<string>& allowed) {
		string groups[6][6]{};//三角形底部两个字母-》[三角形顶部字母]
		for (auto& s : allowed) {
			groups[s[0] - 'A'][s[1] - 'A'] += s[2];
		}

		int n = bottom.size();
		vector<string> pyramid(n);
		for (int i = 0;i < n;i++) {
			pyramid[i].resize(i + 1);
		}
		pyramid[n - 1] = move(bottom);
		
		//现在准备填[i,j]
		//返回继续填能否填完所有格子(从下往上填,每行从左到右填)
		auto dfs = [&](auto&& dfs, int i, int j)->bool {
			if (i < 0) { //所有格子都已填完
				return true;
			}

			if (j == i + 1) { //i行已填完
				return dfs(dfs,i - 1, 0); //开始填i-1行
			}

			//枚举(i,j)填什么字母
			//这取决于(i+1,j)和(i+1,j+1)填的字母
			for (char top : groups[pyramid[i + 1][j] - 'A'][pyramid[i + 1][j + 1] - 'A']) {
				pyramid[i][j] = top;
				if (dfs(dfs,i, j + 1)) {
					return true;
				}
			}
			return false;
		};

		//倒数第二行开始填
		return dfs(dfs, n - 2, 0);
	}
};
相关推荐
汉克老师1 小时前
GESP6级C++考试语法知识(十七、数据结构(三、认识队列 Queue))
数据结构·c++·队列·gesp6级·gesp六级·数组模拟队列
j_xxx404_3 小时前
Linux进程信号捕捉与操作系统运行本质深度解析
linux·运维·服务器·开发语言·c++·人工智能·ai
vx-程序开发3 小时前
基于机器学习的动漫可视化系统的设计与实现-计算机毕业设计源码08339
java·c++·spring boot·python·spring·django·php
啊董dong4 小时前
noi-2026年5月12号小测验
数据结构·c++·算法
咩咦5 小时前
C++学习笔记24:构造函数初始化列表
c++·学习笔记·类和对象·构造函数·初始化列表·const引用
计算机安禾5 小时前
【c++面向对象编程】第43篇:可变参数模板(C++11):优雅处理不定长参数
java·开发语言·c++
10岁的博客6 小时前
C++ 进制转换:通用 a 进制转 b 进制(2-36进制)题解
开发语言·c++
小贾要学习7 小时前
【Linux】基于自定义TCP协议的日期计算器
linux·网络·c++·网络协议·tcp/ip
YsyaaabB7 小时前
ACM 模式通用代码模板
java·c++·python·算法
我命由我123457 小时前
C++ - 面向对象 - 析构函数
android·c语言·开发语言·c++·visualstudio·visual studio·android runtime