当前位置: 首页 > news >正文

河北邯郸中考成绩查询网站金华网站建设外包

河北邯郸中考成绩查询网站,金华网站建设外包,无锡新吴区住房建设交通局网站,linuxvps建站教程动态规划(Dynamic Programming,简称 DP)是一种用于解决多阶段决策最优化问题的算法策略。它通过把原问题分解为相对简单的子问题,记录子问题的解(通常使用表格等数据结构存储),避免重复计算&…

动态规划(Dynamic Programming,简称 DP)是一种用于解决多阶段决策最优化问题的算法策略。它通过把原问题分解为相对简单的子问题,记录子问题的解(通常使用表格等数据结构存储),避免重复计算,从而高效地解决复杂的全局最优问题。
在这里插入图片描述

目录

  • 小红取数
    • 算法思路
    • 代码实现

小红取数

小红取数
在这里插入图片描述

算法思路

由于不同的选择组合,除以k后得到的余数也不相同,当选择一个数加上后,所得到的新值除以k后余数有可能会发生变化,而为了将这些值都能存起来并且找出最大的且余数为0的组合,我们要使用动态规划。因为能产生的余数有k中情况,于是创建一个长度为kdp数组。j作为dp数组的索引也表示相应位置存放的数值除k后的余数,所以最终的答案一定是dp[0]上的数。动态规划的初始状态就是所有数都不选,即和为0的时候余数为0,所以dp[0]初始设为0而其余的位置设为负无穷。用num遍历数组中的每个数,然后尝试加到dp数组中的每一个值上,得到新值为dp[j]+num,很容易会想到这个新值除以k的余数为(dp[j]+num)%k。但是!如果用(dp[j]+num)%k作为索引去访问dp中的元素就出现了bug,这是因为我们初始化的时候把索引0后的位置设为了负无穷,这样导致产生了无效的索引。为了能成功访问到新值除以k后的余数所对应的位置,可以利用同余的性质,当前位置的数除以k的余数为j是规定好的,而这个数在加上num之后,他除以k后的余数就为(j+num%k)%k。接着找到余数为(j+num%k)%k的位置上的值dp[(j+num%k)%k]dp[j]+num作比较,取较大者更新即可。而为了避免产生垃圾数据,在循环内部的操作都是在dp的副本数组上实现的,循环结束后再更新原dp数组

代码实现

n,k = map(int, input().split())
a = list(map(int, input().split()))
dp = [float('-inf')]*k
dp[0] = 0 
for num in a:new_dp = dp[:]# 复制一份dpfor j in range(k):# 遍历每个余数所对应的位置new_dp[(j+num%k)%k] = max(new_dp[(j+num%k)%k], dp[j]+num)# 如果当前余数的位置上的值加上num后得到的这个数大于这个数除k的余数的位置上的值,则更新dp = new_dp# 更新dp
print(dp[0] if dp[0] > 0 else -1)
http://www.yayakq.cn/news/971260/

相关文章:

  • 管理手机网站文化传媒公司
  • 网站点击排名网站 数据库 sql 导入
  • 中冶东北建设最新网站信息网络公司经营范围
  • 收费网站推广桃花岛网站是什么
  • 网站首页布局设计教程网站 实名认证
  • 做网站常用的背景图像WordPress 多个分类目录
  • h5企业网站源码下载电子商务网站建设李洪心课后答案
  • 企业手机网站案例dede中英文网站切换
  • 绵阳的网站制作公司哪家好宁德seo
  • 国内开源建站cms公司网站建设要注意的问题
  • 买的虚拟主机怎么做网站如何做网站 做论坛
  • 盐城seo网站优化公众号开发渠道二维码怎么做
  • 网站备案贵州电话网站的维护步骤
  • 网站建设优化排名个人网站网站
  • wordpress 站外链接如何装wordpress
  • 桂林网站建设哪家好人力资源管理就业方向
  • js 网站制作龙岩兼职
  • 国际婚恋网站做翻译合法吗淮安市住房和城乡建设局网站首页
  • 网页设计与网站建设的区别装修高端网站建设
  • 电白手机网站建设公司本地wordpress打开慢
  • 网站建设图文片手机制作网页多少钱
  • 做的网站首页图片显示不出来优必选网站
  • 网站建设网页模板下载上海袜网站建设
  • 个人建网站一般多少钱app开发技术路线
  • 网站正能量免费推广软件建立公司
  • 专业手机网站建设平台网站建设徐州百度网络网站
  • 卫生局网站建设方案租车行网站模版
  • 景德镇网站网站建设请人做网站安全
  • 南山网站开发服务类产品
  • sedo这种多语言网站怎么建设WordPress中文替换布