交错字符串-二维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;
}
相关推荐
月光船幽幽14 分钟前
Helio-Core临界控制:守护拓扑量子稳定
人工智能·科技·动态规划·拓扑学
罗西的思考17 分钟前
【Agentic RL / 强化学习 / OPD】OpenClaw-RL 源码阅读笔记 --- (4)--- 系统架构
人工智能·算法·机器学习
QiLinkOS19 分钟前
从技术到资产的跃迁:企业专利布局的深层逻辑
c语言·数据结构·c++·单片机·嵌入式硬件·算法·开源
aini_lovee26 分钟前
FMCW雷达测速测距系统(锯齿波 + CFAR检测)
算法
qq_2975746729 分钟前
设计模式系列文章(基础篇第 11 篇):模板方法模式——定义算法骨架,实现代码复用与流程统一
算法·设计模式·模板方法模式
lqqjuly36 分钟前
知识蒸馏:理论、算法与可运行实现
人工智能·深度学习·算法
水上冰石1 小时前
comfui的sd1.5模型,有多少采样算法,详解每一个采样算法
人工智能·算法
黎阳之光1 小时前
视频孪生+空天地水工融合,黎阳之光构建智慧水利监测新范式
大数据·人工智能·物联网·算法·安全
cheems95271 小时前
[算法手记] 贪心 爬楼梯问题
算法·贪心算法
KaMeidebaby1 小时前
卡梅德生物技术快报|酵母双杂交 cDNA 文库构建与蛋白互作筛选流程
服务器·前端·数据库·人工智能·算法