有些题表面上看是一道字符串问题,实际却是一道dp.
我们可以知道,在每一个位置有两种状态,i表示a串下标,j表示b串下标。
1、a[i]==b[i] --> dp[i][j]=dp[i-1][j-1]+1
2、a[i]!=b[j]–> dp[i][j]=max(dp[i][j-1],dp[i-1][j]
所以判断每个位置的状态,DP求解就可以了。
思路确实很简单,下面我们直接上代码
#include<bits/stdc++.h>
using namespace std;
string a,b;
int dp[10001][10001];
int main()
{
cin>>a>>b;
int la=a.length(),lb=b.length();
for(int i=1;i<=la;i++)
{
for(int j=1;j<=lb;j++)
{
if(a[i-1]==b[j-1]) dp[i][j]=dp[i-1][j-1]+1;
else dp[i][j]=max(dp[i][j-1],dp[i-1][j]);
}
}
cout<<dp[la][lb]<<endl;
return 0;
}
这道题非常简单,所以我们要去注意一些细节,我们首先要知道这里面dp数组的默认值都是0,这点是很重要的,别的好像也没啥了,就这吧。