将此代码从递归 DP 转换为迭代 DP
Translate this code from recursive to iterative DP
double R(int N, int x[206], int i, int c){
if (memo[i][c] != 0) return memo[i][c];
if (i==N){
if (c>=23) return 1;
else return 0;
}
double s;
s = R(N,x,i+1,c+x[i]);
s += R(N,x,i+1,c-x[i]);
memo[i][c] = s;
return s;
}
现在这是一个递归记忆函数,但如果可能的话,我想将其转换为迭代等效 DP。或者这是我能做到的唯一方法?
理论上,您可以将任何递归方法转换为迭代方法。所以,是的,这段代码也可以。
更多关于它的信息在这个线程中:https://stackoverflow.com/questions/931762/can-every-recursion-be-converted-into-iteration
由于 x 可以包含任意整数,因此您实际上应该计算 i
固定的任何 c
值的R
。一些代码来解释:
// case where i == N
for (int c = INT_MIN; c < INT_MAX; ++c) {
memo[N][c] = (c>=23) ? 1 : 0;
}
for (int k = N - 1; k >= i; --k) {
for (int c_ = INT_MIN; c_ < INT_MAX; ++c_) {
memo[k][c_] = memo[k+1][c_ + x[k]] + memo[k+1][c_ - x[k]];
}
}
return memo[i][c];
也许对x
值的一些限制可以帮助改善结果。
相关文章:
- 防止主数据类型C++的隐式转换
- 模板参数替换失败,并且未完成隐式转换
- 努力将整数转换为链表。不知道我在这里做错了什么
- HEX值到wchar_t字符(UTF-8)的转换
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将 Qvector<uint8_t> 转换为 QString
- 如何在cuSparse中使用cusparseXcoo2csr从coo转换为csc
- 有关插入适配器的错误。[错误]请求从 'back_insert_iterator<vector<>>' 类型转换为非标量类型
- 在c++中使用nlohmann从类到json的转换
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 将Integer转换为4字节的unsined字符矢量(按大端字节顺序)
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 如何使用OpenCV将RBG图像转换为HSV,并将H、S和V值保存为C++中的3个独立图像
- 复制列表初始化的隐式转换的等级是多少
- 正在将指针转换为范围
- 如何防止 c++ 在从浮点型转换为双精度型(不适用于 IO)时添加额外的小数?
- 将"打开的CV图像"中的"颜色"转换为整数格式
- 是否可以从int转换为enum类类型
- 从 CPP 到 Java 的转换 (dp =1)
- 将此代码从递归 DP 转换为迭代 DP