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

3d云打印网站开发深圳住房建设局官方网站

3d云打印网站开发,深圳住房建设局官方网站,做电商一件代发的网站,建设企业网站流程题目 输入样例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 1; i 13; i ) res (res f[n][m][k][i]) % MOD;cout res;return 0; }感觉DP就是根据集合定义打好表算出全部的状态的值然后查询表中符合题目要求的状态值。
http://www.hkea.cn/news/14269830/

相关文章:

  • 网站网站制作400多少钱城乡建设部注册建筑师网站
  • 男孩子怎么做网站推广wordpress上传图片x
  • 成都个人网站做网站思想
  • 城市建设模拟游戏登陆网站视频制作哪里可以学
  • 贵阳白云区城乡建设局网站土特产网站模板 织梦
  • 做网站一定要备案吗如何建设网站和app
  • 建个人网站要多少钱个人网站建设方案书用备案的
  • 黄页网站推广app咋做广告thinkphp做网站教程
  • WordPress下如何用页面做侧边栏seo服务公司深圳
  • 昆明网络公司开发网站seo三要素
  • 网站运营培训机构网站建设综合实训
  • 基于jquery做的网站抖音产品推广方案
  • 门户网站微信服务号建设方案如何利用互联网挣钱
  • 微信引流神器手机电影网站怎么做合肥市建设工程信息网官网
  • 网站后台主流网站开发语言福州建设工程造价信息网
  • 产品营销类网站织梦修改网站标题
  • 免费咨询合肥网站优化哪家好
  • 重庆信息网官网系统优化app
  • 类似于拼多多的网站怎么做高清视频网络服务器免费
  • 老鹰主机做的网站房源信息网
  • 建设网站要多久的时间怎么做网站关键词优化
  • WordPress5分钟建站做游戏代练网站
  • wordpress博客网站重庆小程序开发公司
  • 重庆网站建设有佳网络商品详情页设计
  • 浏览器正能量网站百度下载安装免费下载
  • 做网站输入文本框做下拉自己制作图片文字图片
  • 河南企业网站制作大连网页模板建站
  • 河间做网站 申梦网络哪些做调查问卷挣钱的网站
  • 三亚旅游网站策划书网站是指什么
  • 企业建站系统平台wordpress文章前台看不到