鱼C论坛

 找回密码
 立即注册
查看: 1977|回复: 6

[已解决]数字三角型

[复制链接]
发表于 2022-5-4 12:14:56 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
题目 : https://www.luogu.com.cn/problem/P1216
我的代码不知道怎么回事, 不输出...
  1. #include <bits/stdc++.h>
  2. using namespace std;

  3. int main(){
  4.         ios::sync_with_stdio(0);
  5.         int r;
  6.         cin >> r;
  7.         vector<vector<int>> tri(r+1, vector<int>(r+1));
  8.         for(int i = 0; i < r; i++){
  9.                 for(int j = 0; i <= i; j++){
  10.                         cin >> tri[i][j];
  11.                 }
  12.         }
  13.         
  14.         for(int i = r-2; i >= 0; i--){
  15.                 for(int j = 0; i <= i; j++){
  16.                         tri[i][j] += max(tri[i+1][j], tri[i+1][j+1]);
  17.                 }
  18.         }
  19.         cout << tri[0][0];
  20.         return 0;
  21. }
复制代码

大伙帮忙看看~
最佳答案
2022-5-4 13:52:49
柿子饼同学 发表于 2022-5-4 13:37
最后用这个方法AC了
但是还是不知道递归的初始状态怎么写...

也行,本来想说用递归方法的(二叉树),但又发现重复子问题,还是像你的代码一样用循环比较好,想到 r <= 1000 行,最大 500500个数字,用递归也不合适,消耗资源太大了。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-5-4 12:16:26 | 显示全部楼层
就是从倒数第二层开始, 每次给 i, j 加上下面两个数字中的大者
这样循环之后第一层就是最大值了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-5-4 12:27:06 | 显示全部楼层
柿子饼同学 发表于 2022-5-4 12:16
就是从倒数第二层开始, 每次给 i, j 加上下面两个数字中的大者
这样循环之后第一层就是最大值了

这个题目跟你之前几题相似,可以用之前递归方法找出最优解
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-5-4 13:37:56 | 显示全部楼层
傻眼貓咪 发表于 2022-5-4 12:27
这个题目跟你之前几题相似,可以用之前递归方法找出最优解
  1. #include <bits/stdc++.h>
  2. using namespace std;

  3. int main(){
  4.         ios::sync_with_stdio(0);
  5.         int r;
  6.         cin >> r;
  7.         vector<vector<int>> tri(r, vector<int>(r));
  8.         for(int i = 0; i < r; i++){
  9.                 for(int j = 0; j <= i; j++){
  10.                         cin >> tri[i][j];
  11.                 }
  12.         }
  13.         for(int i = r-2; i >= 0; i--){
  14.                 for(int j = 0; j <= i; j++){
  15.                         tri[i][j] += max(tri[i+1][j], tri[i+1][j+1]);
  16.                 }
  17.         }
  18.         cout << tri[0][0];
  19.         return 0;
  20. }
复制代码

最后用这个方法AC了
但是还是不知道递归的初始状态怎么写...
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-5-4 13:52:49 | 显示全部楼层    本楼为最佳答案   
柿子饼同学 发表于 2022-5-4 13:37
最后用这个方法AC了
但是还是不知道递归的初始状态怎么写...

也行,本来想说用递归方法的(二叉树),但又发现重复子问题,还是像你的代码一样用循环比较好,想到 r <= 1000 行,最大 500500个数字,用递归也不合适,消耗资源太大了。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-5-4 14:56:43 | 显示全部楼层
傻眼貓咪 发表于 2022-5-4 13:52
也行,本来想说用递归方法的(二叉树),但又发现重复子问题,还是像你的代码一样用循环比较好,想到 r

哈哈哈二叉树我没学过...
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-5-4 17:32:00 | 显示全部楼层
柿子饼同学 发表于 2022-5-4 14:56
哈哈哈二叉树我没学过...

我尝试用递归做出动态规划,没想到也行,但不知其它数据可以不可以正常 AC 呢?
动态规划公式:sum[x][y]=max(sum[x+1][y],sum[x+1][y+1])+arr[x][y]
  1. #include <iostream>
  2. #include <algorithm>
  3. #include <vector>

  4. using std::vector, std::max;
  5. int foo(vector<vector<short>> arr, int x = 0, int y = 0) {
  6.         if (x >= arr.size()) return 0;
  7.         return arr[x][y] + max(foo(arr, x + 1, y), foo(arr, x + 1, y + 1));
  8. }

  9. using std::cin, std::cout, std::endl;
  10. int main(void) {
  11.         short r, num;
  12.         cin >> r;
  13.         vector<short> temp;
  14.         vector<vector<short>> arr(r, temp);
  15.         for (int i = 0; i < r; ++i) {
  16.                 for (int j = 0; j < i + 1; ++j) {
  17.                         cin >> num;
  18.                         arr[i].push_back(num);
  19.                 }
  20.         }
  21.         cout << foo(arr) << endl;
  22.         return 0;
  23. }
复制代码
  1. 5
  2. 7
  3. 3 8
  4. 8 1 0
  5. 2 7 4 4
  6. 4 5 2 6 5
  7. 30
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-5 06:20

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表