哈夫曼树_ 2023-04-01 23:40 采纳率: 57.7%
浏览 29
已结题

Python 蓝桥杯 部分测试用例不通过

题目链接: https://www.lanqiao.cn/problems/505/learning/?page=1&first_category_id=1&sort=students_count&second_category_id=3

import os
import sys

# 请在此输入您的代码

N = eval(input())
tri = [list(map(int,input().split())) for x in range(N)]
dp = tri

for i in range(1, N):
  for j in range(i + 1):
    if j == 0:   # 第一列
      dp[i][j] = dp[i - 1][j] + tri[i][j]
    elif j == i:   # 最后一列
      dp[i][j] = dp[i - 1][j - 1] + tri[i][j]
    else:
      dp[i][j] = max(dp[i - 1][j -1], dp[i - 1][j]) + tri[i][j]

print(max(dp[-1]))

我的想法是dp[i][j]用来存储到达数字三角形的(i, j)位置的最大和, 题目要求求出到达底部的最大和,那么就是dp的最后一行中最大的元素,即max(dp[-1]), 但是结果表明只有20%的用例通过。

img

问题出现在哪里?

  • 写回答

2条回答 默认 最新

  • 请叫我问哥 Python领域新星创作者 2023-04-02 00:46
    关注

    你的思路没问题,但是审题不仔细:“此外,向左下走的次数与向右下走的次数相差不能超过 1。”
    这句话使得本题最后的结果只能落在最后一行的中位数上。

    在你的代码的基础上修改一下最后输出的部分就没问题了:

    N = eval(input())
    tri = [list(map(int,input().split())) for x in range(N)]
    dp = tri
    
    for i in range(1, N):
      for j in range(i + 1):
        if j == 0:   # 第一列
          dp[i][j] = dp[i - 1][j] + tri[i][j]
        elif j == i:   # 最后一列
          dp[i][j] = dp[i - 1][j - 1] + tri[i][j]
        else:
          dp[i][j] = max(dp[i - 1][j -1], dp[i - 1][j]) + tri[i][j]
    
    if N & 1:
      print((dp[-1][N//2]))
    else:
      print(max(dp[-1][N//2], dp[-1][(N//2)-1]))
    
    本回答被专家选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 5月14日
  • 专家已采纳回答 5月6日
  • 创建了问题 4月1日

悬赏问题

  • ¥15 preLaunchTask"C/C++: aarch64- apple-darwin22-g++-14 生成活动 文件”已终止,退出代码为-1。
  • ¥18 关于#贝叶斯概率#的问题:这篇文章中利用em算法求出了对数似然值作为概率表参数,然后进行概率表计算,这个概率表是怎样计算的呀
  • ¥20 C#上传XML格式数据
  • ¥15 elementui上传结合oss接口断点续传,现在只差停止上传和继续上传,各大精英看下
  • ¥100 单片机hardfaulr
  • ¥20 手机截图相片分辨率降低一半
  • ¥50 求一段sql语句,遇到小难题了,可以50米解决
  • ¥15 速求,对多种商品的购买力优化问题(用遗传算法、枚举法、粒子群算法、模拟退火算法等方法求解)
  • ¥100 速求!商品购买力最优化问题(用遗传算法求解,给出python代码)
  • ¥15 虚拟机检测,可以是封装好的DLL,可付费