RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1600925
Accepted
user27630724
user27630724
Asked:2024-11-27 00:38:39 +0000 UTC2024-11-27 00:38:39 +0000 UTC 2024-11-27 00:38:39 +0000 UTC

DP 任务。我不明白出了什么问题

  • 772

通过问题E-蚱蜢和青蛙的解决方案 满分:100 时间限制:2秒 实时限制:5秒 内存限制:256M 问题E:蚱蜢和青蛙 问题条件(pdf)

蚱蜢沿着位于同一条线上且彼此距离相等的柱子跳跃。这些列的序列号为 1 到 N。一开始,蚱蜢坐在编号为 1 的柱子上。他可以向前跳跃 1 到 K 柱的距离,从当前的柱子开始计算。

有些帖子上有青蛙吃蚱蜢(蚱蜢不应该落在这些帖子上!)。确定 Grasshopper 可以通过多少种方式安全到达编号为 N 的列。请记住,Grasshopper 无法向后跳。输入格式 输入字符串包含自然数 N 和 K,以空格分隔。保证1≤N,K≤32。第二行包含青蛙的数量 L (0≤L≤N−2)。第三行包含L个自然数:青蛙所坐的列数(其中没有数字为1和N的列)。

Примеры
Входные данные
6 4
2
2 4
Выходные данные
3

我不明白出了什么问题,并非所有测试都通过

n, k = map(int, input().split())
l = int(input())
s_l = list(map(int, input().split()))
dp = [1] * n
dp_1 = []
for i in range(l):
    dp[s_l[i] - 1] = 0
dp_1 = []
dp_1.append(dp[0])
print(dp)
for i in range(1,n):
    if dp[i] == 0:
        pass
    else:
        if i < k:
            dp_1.append(sum(dp_1[:i]))
        else:
            dp_1.append(sum(dp_1[i - k:i]))
print(dp_1[-1])
python-3.x
  • 1 1 个回答
  • 34 Views

1 个回答

  • Voted
  1. Best Answer
    MBo
    2024-11-27T00:50:20Z2024-11-27T00:50:20Z

    您dp1不添加带有青蛙的列,这意味着按范围进行的计算将会混乱 -i - k它将捕获比必要的更早的列

    if dp[i] == 0:
        dp_1.append(0)
    

    PS 实际上,为什么需要 dp1 呢?

    n, k = map(int, input().split())
    l = int(input())
    s_l = list(map(int, input().split()))
    dp = [1] * n
    for i in range(l):
        dp[s_l[i] - 1] = 0
    for i in range(1,n):
        if dp[i]:
            if i < k:
                dp[i] = sum(dp[:i])
            else:
                dp[i] = sum(dp[i - k:i])
    print(dp[-1])
    

    下一步,如果需要对大N(对于N=32就可以了)进行优化,就是放弃每次求和,并通过累加(累积)和的差值来找到范围的总和。

    为此,我们将获得的 dp[] 值汇总到一个附加列表 cumsum[] 中

    cumsum[i] = cumsum[i-1] + dp[i]
    

    并且总和sum(dp[i - k:i])等于差cumsum[i-1] -cumsum[i-k-1]。

    但更重要的是,在这种情况下不需要单独的列表。我们只需将结果值相加并减去区间左端的值(我就写在这里,需要更精确地检查索引)

     dp[i] = partsum
     partsum  += dp[i]
     if i >= k:
        partsum -= dp[i-k-1]
      
    
    • 4

相关问题

  • 在 Linux 服务器上运行 Django 项目

  • 当您单击kivy设置中的关闭按钮时,如何调用更新应用程序本身的gui的方法

  • 制作一个按钮处理程序来调用该函数。那些。单击按钮时,该函数应运行。遥控机器人

  • 如何正确地将列表项添加到 Word 表格中?

  • 内容解析(Python、BeautifulSoup、请求)

  • 脚本不适用于 BeautifulSoup 和请求 (Python3x)

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5