当前位置: 首页 > 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/14444695/

相关文章:

  • 北京网站建设签约免费好用的网站制作
  • 网站域名到期惠州市企业网站seo点击软件
  • 企业网站建设方式立即关注公众号
  • 给企业做网站的公司专业的外贸网站建设公司
  • 网站优化建设安徽发广告去哪个平台
  • 辽宁网站备案小型个人网站制作
  • 内部网站建设拓扑wordpress自适应手机端
  • 企业网站管理系统排名如何建设小网站
  • 什么软件能看网站?aso如何优化
  • 入门网站分析应该怎么做WordPress怎么去掉主题也没
  • 网站开发与管理课程seo推广是什么工作
  • 连云港建设局官方网站网站专题建设方案
  • 江苏省建设厅网站查询多钱网网站
  • 北京天海网站建设公司网站设计多少钱市场价
  • 动图制作网站手机个别网页打不开
  • php网站登录系统怎么做wordpress 头像插件
  • 运城网站建设瑞安哪里有做百度的网站
  • 广州网站建设好公司深圳公司网站建设哪家好
  • 单位网站建设工作功劳asp网站开发实训
  • 永康物流网站中国建筑网招聘信息
  • 旅游网站wordpress集团做网站需要多大的带宽
  • 关于网站建设的简历网站推广论坛
  • 深圳建设银行网站首页页面设计快捷键
  • 百度不收录哪些网站深圳市建设局官方网站
  • 欧美风格英文网站设计企业网站建设推广实训报告
  • 顺德做外贸网站网站优化可以做哪些优化
  • 卫生局网站建设方案网站开发的费用属于什么科目
  • 网站域名密码找回wordpress iis
  • 网站设计怎么做做电脑网站用什么软件好用吗
  • 汉口网站推广优化推广服务商是什么意思