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

网站建设招标书模板合肥网红

网站建设招标书模板,合肥网红,一般网站建设企业,湛江电气建站软件题目 输入样例1#xff1a; 2 2 2 1 2 2 1输出样例1#xff1a; 2输入样例2#xff1a; 2 3 2 1 2 3 2 1 5输出样例2#xff1a; 14 思路 题目说从入口开始#xff0c;只能向右或向下行走到达右下角#xff0c;类似“摘花生”这道题的模型。题目又说只有当格子里的宝…题目 输入样例1 2 2 2 1 2 2 1输出样例1 2输入样例2 2 3 2 1 2 3 2 1 5输出样例2 14 思路 题目说从入口开始只能向右或向下行走到达右下角类似“摘花生”这道题的模型。题目又说只有当格子里的宝贝价值比小明手中任意宝贝价值都大小明就可以拿起它也就说拿到的宝贝价值严格单调递增是“单调递增子序列”的模型。 状态表示         那用几维才能表示一个状态呢首先需要用 i, j 来表示从起点走到 (i, j) 这个格子的所有路径方案数然后需要用ki来表示从起点走到(i, j)这个格子拿了多少个物品最后由于拿到的宝贝价值要严格单调递增因此需要用C表示拿到的最后一个物品的价值。 那为什么我们不用最后一个物品的坐标来表示状态呢通过坐标也可以得到最后一个物品的价值啊因为有50 x 50个坐标并且是这样做会使一个状态表示的维数达到五维时间复杂度也会增加。题目中取到宝贝的价值有限(0≤Ci≤12)因此可以用C代表最后取到的宝贝的最大值即可这样可以将维数降到四维。 综上所述我们可以将集合f[i][j][ki][c]定义为所有从起点走到(ij)且已经取了ki件物品且最后一件物品的价值是C的合法方案的集合。集合属性为满足集合定义的方案数总和。 状态计算 由于到达(i, j)这个点只能从左边或上边来因此可以将集合划分为所有最后一步是从上往下走的走法的集合和所有最后一步是从左往右走的走法的集合。而对于所有最后一步是从上往下走的走法的集合又可以划分为取不取(i, j)这个格子的宝贝这两个小的集合当要取(i, j)这个格子的宝贝时说明这个格子里宝贝价值value比前面拿到的任何宝贝的价值都大并且根据集合定义f[i][j][ki][c]存的是最后一件物品的价值是c的合法方案的集合因此当枚举c时若要取(i, j)这个格子的宝贝还需要满足value等于c。 边界处理         需要注意的是由于宝贝的价值可能为0当左上角格子的的宝贝价值为0时不拿可以表示为f[1][1][0][0] 1但下一步向右或向下走遇到一个格子的宝贝价值为0就不能拿了因为题目要求拿到的宝贝价值要严格单调递增而实际上若没有拿左上角格子价值为0的宝贝在下一步遇到一个价值为0的宝贝是可以选择拿或不拿的。 对此我们可以将所有格子里宝贝的价值都加上1宝贝价值区间变成1≤Ci≤13当c为0时表示还没有拿过任何一件宝贝“最后一个物品价值为0”。这样处理后当左上角格子的的宝贝价值为1时不拿可以表示为f[1][1][0][0] 1当下一步向右或向下走遇到一个格子的宝贝价值为1就可以选择拿或不拿了。 int 范围为2.1 x 10^9因此val最多加两个数就要取模了。 代码 #includebits/stdc.h using namespace std; const int MOD 1000000007, N 55; int a[N][N], f[N][N][13][14]; int n, m, k, res;int main() {cin n m k;for (int i 1; i n; i ){for (int j 1; j m; j ){cin a[i][j];a[i][j] ;}}int res 0;f[1][1][1][a[1][1]] 1, f[1][1][0][0] 1;for (int i 1; i n; i ){for (int j 1; j m; j ){if (i 1 j 1) continue;for (int ki 0; ki k; ki ){for (int value 0; value 13; value ){int val f[i][j][ki][value];//不能选(i, j)这个格子里的宝贝//从上往下走并且不取(i, j)上的宝贝的方案数val (val f[i - 1][j][ki][value]) % MOD;//从左往右走并且不取(i, j)上的宝贝的方案数val (val f[i][j - 1][ki][value]) % MOD;if (ki 0 value a[i][j]){for (int c 0; c value; c ){//从前面的状态中选价值c value并且选了ki - 1件的fval (val f[i - 1][j][ki - 1][c]) % MOD;val (val f[i][j - 1][ki - 1][c]) % MOD;}}}}}}for (int i 0; i 13; i ) res (res f[n][m][k][i]) % MOD;cout res;return 0; }感觉DP就是根据集合定义打好表算出全部的状态的值然后查询表中符合题目要求的状态值。
http://www.pierceye.com/news/730917/

相关文章:

  • 个人网站制作wordpress英文注册查询网站
  • 哪里有免费网站空间申请wordpress重定向插件
  • 福州微网站开发什么样的网站快速盈利
  • 吉首市建设局官方网站一对一直播软件开发定制
  • 网站开发验收单做的网站如何被百度搜到
  • 网站的数据库是什么两学一做网站链接
  • 做窗帘网站济南网络科技公司排名
  • 广东省住房城乡建设部网站哪个网站可以做加工代理的
  • dede网站源码打包下载wordpress登不进后台
  • 建设内部网站目的国内贸易在那个网站上做
  • 用什么建设网站注册深圳公司代理
  • 网站平台建设方案书百度云资源搜索入口
  • 网站 团队博罗网站建设哪家便宜
  • wordpress列表分页枣庄seo外包
  • 知了网站后台推广形式有哪几种
  • 成品图片的网站在哪里找wordpress开启防盗链
  • 伊滨区网站建设网站建设经理
  • 权威的郑州网站建设域名租用平台
  • 造价工程师网网站点击排名优化
  • 网站关键词搜索海口网站建设优化公司
  • WordPress建影视站免费的素材网站有哪些
  • 屯留做网站哪里好阿里云服务器618
  • 网站怎么做登录模块免费的编程软件下载
  • 网站建设与管理的策划书网站建设五合一
  • 网站建设管理分工公司招聘网站有哪些
  • 分类信息网站手机版上海网站关键词优化方法
  • 建设个人网站的参考网站及文献怎么做水果网站
  • 台山住房和城乡建设 网站有赞分销
  • 网站备案 历史wordpress货币插件
  • 如何做自助搜券网站佛山顺德专业做网站