题解 1177: 三角形

来看看其他人写的题解吧!要先自己动手做才会有提高哦! 
返回题目 | 我来写题解

筛选

二维dp和一维dp

摘要:解题思路:第i行第j个数只能由第i-1行第j和第j-1的最大值得来;也就是说进行到第f[i][j]个数时f[i][j]=max(f[i-1][j]+a[i][j],f[i-1][j-1]+a[i][j……

C++ 动态规划,反向从下往上计算.

摘要:解题思路:动态规划,将输入的三角形数值存入数组,由题意:每一步只能由当前位置向左下或右下可得在数组中只能从下或右下走,因此从倒数第二行(倒数第一行下面没有元素)元素dp[i][j]计算时,dp[i][……

三角形 (C语言代码)

摘要:解题思路:这其实动态规划算法的一道 入门入门入门 级的题,又称为数塔。解法就是从下往上,两两比较,以样例为例。最下面的4 5 2 6,先4和5比较,二者间大的数与上面的2相加。依次类推。比较规整的代码……

三角形 (C语言代码)

摘要:解题思路:注意事项:参考代码:#include<stdio.h>int main(){ int t,n,i,j,a[100][100]; scanf("%d",&t); while(t--) {  s……

三角形 (C语言代码)

摘要:解题思路:数塔问题。从倒数第二行开始求当前行对应位置与下一行对应位置的两个数最大值之和,一直到第一行,则第一个就是所求数据。参考代码:#include <stdio.h> #include <mat……

三角形-题解(C++代码)动态规划详解

摘要:用一个二维数组存放数字三角形。 W(i,j)表示第i行j列的数字,dp[i][j]表示从第i行j列的数字到底边路径的最大和。 先以递归的方法入手,寻找状态转移方程。对N行三角形: if(i==n……

三角形-题解(Python代码)

摘要:本题笔者直接从最后一排累加得解。 ```python n_test=int(input()) for i_test in range(n_test): n=int(input()) ……

三角形-题解(C++代码)

摘要:```cpp #include using namespace std; int a[105][105] = {0}; int main() { int i, j, t = 0, n,……

三角形-题解(Java代码) 递归记忆化搜索

摘要:第一次解这题时直接用了递归算法,结果50%超时,于是就用记忆化搜索优化一下递归,就是用一个容器将递归中会重复计算的值装起来,等到要进行重复计算时直接调用这个值免去了重复计算的步骤 imp……