交错字符串-二维dp

交错字符串

Solution

这题的状态定义比较巧妙,dp是一个bool类型的数组,dp(i,j)表示s1的前i个字符加上s2的前j个字符是否能够交错形成s3的前i+j个字符。

考虑dp(i,j),当前处于s3的第i+j-1个字符,这个字符有两种可能的来源,可能来自于s1的第i个字符,也可能来自于s2的第j个字符,如果这三个字符都相等,则在两种情况中取一种情况即可,也就是取或。

cpp 复制代码
#include<iostream>
#include<vector>
using namespace std;

//dp做法
bool f1(string s1, string s2, string s3) {
	int n1 = s1.length();
	int n2 = s2.length();
	//dp(i,j)表示s1的前i个字符与s2的前j个字符是否能组成s3的前i+j个字符
	vector<vector<bool>>dp(n1 + 1, vector<bool>(n2 + 1, false));

	if (n1 + n2 != s3.length()) return false;
	//base case
	dp[0][0] = true;
	for (int i = 1; i <= n1; ++i) {
		if (s1[i - 1] == s3[i - 1]) 
			dp[i][0] = true;
		else
			break;
	}
	for (int j = 1; j <= n2; ++j) {
		if (s2[j - 1] == s3[j - 1])
			dp[0][j] = true;
		else break;
	}
	for (int i = 1; i <= n1; ++i) {
		for (int j = 1; j <= n2; ++j) {
			if (s1[i - 1] == s3[i + j - 1] && s2[j - 1] == s3[i + j - 1])
				dp[i][j] = dp[i - 1][j] || dp[i][j - 1];
			else if (s1[i - 1] == s3[i + j - 1] && s2[j - 1] != s3[i + j - 1])
				dp[i][j] = dp[i - 1][j];
			else if (s1[i - 1] != s3[i + j - 1] && s2[j - 1] == s3[i + j - 1])
				dp[i][j] = dp[i][j - 1];
		}
	}
	return dp[n1][n2];
}

//dp+空间压缩
bool f2(string s1, string s2, string s3) {
	int n1 = s1.length();
	int n2 = s2.length();
	int n3 = s3.length();
	if (n1 + n2 != n3) return false;
	vector<int>dp(n2 + 1, false);

	dp[0] = true;
	for (int i = 0; i <= n1; ++i) {
		for (int j = 0; j <= n2; ++j) {
			int p = i + j - 1;
			if (i > 0) {
				dp[j] &= (s1[i - 1] == s3[p]);
			}
			if (j > 0) {
				dp[j] |= (dp[j - 1] && s2[j - 1] == s3[p]);
			}
		}
	}
	return dp[n2];
}
bool isInterleave1(string s1, string s2, string s3) {
	return f1(s1, s2, s3);
}

bool isInterleave(string s1, string s2, string s3) {
	return f2(s1, s2, s3);
}

int main() {

	return 0;
}
相关推荐
AI软著研究员4 小时前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish5 小时前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱6 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
地平线开发者21 小时前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮1 天前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者1 天前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考1 天前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx1 天前
CART决策树基本原理
算法·机器学习
Wect1 天前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
颜酱1 天前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法