咖啡


私信TA

用户名:Tianxn

访问量:128976

签 名:

十年OI一场空,不开LL见祖宗。

等  级
排  名 9
经  验 26163
参赛次数 10
文章发表 197
年  龄 22
在职情况 学生
学  校 西安电子科技大学
专  业 软件工程

  自我简介:

解题思路:

假设两个字符串分别为s1, s2

dp[i, j]表示s1以s1[i - 1]结尾和s2以s2[i - 1]结尾结尾时的最长上升子序列的长度。


注意事项:

dp[len1][0] = dp[0][len2] = 0;

参考代码:

#include <stdio.h>
#include <string.h>
#define max(a, b) a > b ? a : b
char s1[1005], s2[1005];
int dp[1005][1005];

int main() {
	scanf("%s%s", s1, s2);
	int len1 = strlen(s1), len2 = strlen(s2);
	for (int i = 1; i <= len1; ++i) {
		for (int j = 1; j <= len2; ++j) {
			if (s1[i - 1] == s2[j - 1]) 
				dp[i][j] = dp[i - 1][j - 1] + 1;
			else
				dp[i][j] = max(dp[i][j - 1], dp[i - 1][j]);
		}
	}
	printf("%d\n", dp[len1][len2]);
	return 0;
}


 

0.0分

1 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答

代码解释器

  评论区