动态规划(DP)常见的应用场景包括:最长、最优、最大、最小、计数等类型的问题。

解题思路是先写出递归式,再将其转换为 DP 的递推式。

递归式

string sa = "abcd";
string sb = "becd";

int f(int a, int b)
{
	if (a == 0 || b == 0)return 0;
	//最小规模为2个字符的比较
	if (sa[a] == sb[b])
	{
		return  1+ f(a-1,b-1) ;//如果该2字符相等,那么计算下一条,最大程度加1
	}
	else
	{
		return max( f(a - 1, b), f(a, b - 1));// 如果不等 那么 a下一条或b下一条选择最大
	}

}

DP 递推式

	int arr[10][10];
	memset(arr, 0, 4 * 10 * 10);


	for (int a = 1; a <= 4; a++)
	for (int b = 1; b <= 4; b++)
	{
		if (sa[a] == sb[b])
		{
			arr[a][b] = 1 + arr[a - 1][b - 1];
		}
		else
		{
			arr[a][b] = max(arr[a + 1][b], arr[a][b + 1]);
		}




	}

	cout << arr[4][4]<<endl;