我为最长递增子序列提出了简单的以下递归解决方案。但是,你能帮忙把记忆包含到这个递归解决方案中吗?
public int findLIS(int a[], int maxSoFar, int item, int count) {
if(item == a.length) {
return count;
}
int length1 = findLIS(a,maxSoFar, item+1, count);
int length2 = 0;
if(a[item] > maxSoFar) {
length2 = findLIS(a, a[item], item+1, count + 1);
}
return Math.max(length1, length2);
}
PS:这不是作业问题,这更符合我的兴趣。