交错字符串-二维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;
}
相关推荐
玄同76527 分钟前
Python Random 模块深度解析:从基础 API 到 AI / 大模型工程化实践
人工智能·笔记·python·学习·算法·语言模型·llm
Pluchon30 分钟前
硅基计划4.0 算法 简单模拟实现位图&布隆过滤器
java·大数据·开发语言·数据结构·算法·哈希算法
独断万古他化35 分钟前
【算法通关】前缀和:和为 K、和被 K整除、连续数组、矩阵区域和全解
算法·前缀和·矩阵·哈希表
历程里程碑38 分钟前
普通数组-----除了自身以外数组的乘积
大数据·javascript·python·算法·elasticsearch·搜索引擎·flask
AI视觉网奇40 分钟前
blender 导入fbx 黑色骨骼
学习·算法·ue5·blender
weixin_468466851 小时前
目标识别精度指标与IoU及置信度关系辨析
人工智能·深度学习·算法·yolo·图像识别·目标识别·调参
多恩Stone1 小时前
【3D AICG 系列-8】PartUV 流程图详解
人工智能·算法·3d·aigc·流程图
铸人1 小时前
再论自然数全加和-质数的规律
数学·算法·数论·复数
历程里程碑2 小时前
Linux22 文件系统
linux·运维·c语言·开发语言·数据结构·c++·算法
你撅嘴真丑9 小时前
第九章-数字三角形
算法