leetcode 131 —— Palindrome Partitioning

本文介绍了使用动态规划和回溯方法解决字符串回文分组问题。通过构建回文子串矩阵并递归搜索所有可能的回文组合,实现字符串的有效分组。

Given a string s, partition s such that every substring of the partition is a palindrome.

Return all possible palindrome partitioning of s.

For example, given s = "aab",
Return

  [
    ["aa","b"],
    ["a","a","b"]
  ]

思路: DP+ 回溯


class Solution {
public:
	vector<vector<string>> res;
	int n;
	vector<vector<string>> partition(string s) {
		n = s.size();
		vector<vector<bool>> dp(n,vector<bool>(n,false));
		for (int i = 0; i < n; i++){
			for (int j = 0; j < n-i; j++){
				if (s[j+i] == s[j]){
					if (i <= 1)
						dp[j][j+i] = true;
					else
						dp[j][j+i] = dp[j + 1][j+i-1];
				}
			}
		}
		vector<string> path;
		dfs(0, path, s, dp);
		return res;
	}
	void dfs(int level, vector<string> &path, string &s, vector<vector<bool>> &dp){
		if (level == n){
			res.push_back(path);
			return;
		}
		for (int i = level; i < s.size(); i++){
			if (dp[level][i]){
				path.push_back(s.substr(level, i - level + 1));
				dfs(i + 1, path, s, dp);
				path.pop_back();
			}
		}
	}
};




乐播投屏是一款简单好用、功能强大的专业投屏软件,支持手机投屏电视、手机投电脑、电脑投电视等多种投屏方式。 多端兼容与跨网投屏:支持手机、平板、电脑等多种设备之间的自由组合投屏,且无需连接 WiFi,通过跨屏技术打破网络限制,扫一扫即可投屏。 广泛的应用支持:支持 10000+APP 投屏,包括综合视频、网盘与浏览器、美韩剧、斗鱼、虎牙等直播平台,还能将央视、湖南卫视等各大卫视的直播内容一键投屏。 高清流畅投屏体验:腾讯独家智能音画调校技术,支持 4K 高清画质、240Hz 超高帧率,低延迟不卡顿,能为用户提供更高清、流畅的视觉享受。 会议办公功能强大:拥有全球唯一的 “超级投屏空间”,扫码即投,无需安装。支持多人共享投屏、远程协作批注,PPT、Excel、视频等文件都能流畅展示,还具备企业级安全加密,保障会议资料不泄露。 多人互动功能:支持多人投屏,邀请好友加入投屏互动,远程也可加入。同时具备一屏多显、语音互动功能,支持多人连麦,实时语音交流。 文件支持全面:支持 PPT、PDF、Word、Excel 等办公文件,以及视频、图片等多种类型文件的投屏,还支持网盘直投,无需下载和转格式。 特色功能丰富:投屏时可同步录制投屏画面,部分版本还支持通过触控屏或电视端外接鼠标反控电脑,以及在投屏过程中用画笔实时标注等功能。
### LeetCode 20 有效的括号 C++ 解法 对于 LeetCode 第 20 题“有效的括号”,其核心在于通过栈的数据结构来验证输入字符串中的括号是否能够正确匹配。以下是基于栈的 C++ 实现方案: #### 方法概述 该方法利用栈的特点——先进后出(FILO),逐一遍历输入字符串 `s` 中的字符。如果当前字符是一个开括号,则将其压入栈中;如果是闭括号,则尝试从栈顶弹出一个对应的开括号进行匹配。最终,当遍历完成后,若栈为空则表示所有括号均成功匹配。 #### 具体实现代码 以下提供了完整的 C++ 实现代码[^2]: ```cpp class Solution { public: bool isValid(string s) { std::stack<char> m_stack; for (const auto& v : s) { if (m_stack.empty()) { m_stack.push(v); } else if (compare(m_stack.top(), v)) { m_stack.pop(); } else { m_stack.push(v); } } return m_stack.size() == 0 ? true : false; } private: bool compare(const char& c1, const char& c2) { return (c1 == '(' && c2 == ')') || (c1 == '[' && c2 == ']') || (c1 == '{' && c2 == '}'); } }; ``` 上述代码定义了一个名为 `Solution` 的类,并在其内部实现了成员函数 `isValid` 和辅助私有函数 `compare`。其中: - 函数 `isValid` 负责接收输入字符串并返回布尔值以表明括号序列是否有效。 - 辅助函数 `compare` 则用于检测两个字符是否构成一对合法的括号组合。 #### 复杂度分析 时间复杂度为 O(n),因为每个字符最多只会被压入和弹出一次堆栈操作。空间复杂度同样也是 O(n),最坏情况下整个字符串都需要存储到栈里[^4]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值