当前位置: 首页 > 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.zqtcl.cn/news/890310/

相关文章:

  • 建设银行网站短信错误6次wordpress新主题去版权
  • 国外 配色网站天猫店购买交易平台
  • 网站推广广告词大全集网站和网络建设自查报告
  • 电子商务网站建设备案须知自己做的网站服务器在哪里
  • 怎样用wordpress做网站wordpress 首页判断
  • jsp做的网站效果织梦网站程序模板
  • 展示型网站设计公司网盘wordpress
  • 网站建设 保密学服装设计后悔了
  • 网站建设前端和后端网站开发所遵循的
  • 有自己域名的个人网站企业网站建设制作公司
  • 工程行业网站优化网站推广排名
  • 青岛网站建设软件下载广州app网站建设
  • 天津市建设厅官方网站qq电脑版登录
  • 贵阳手机网站建设公司辽源网站建设
  • 淄博网站设计制作wordpress 纯静态首页
  • 规划电子商务网站流程福清建设局网站简介
  • 使用joomla的网站网络营销师资格证有什么用
  • 做经营网站怎么赚钱吗关于做网站的合同
  • 上海手机网站建设哪家好重庆景点
  • 做网站菜单背景图片wordpress伪原创词库
  • 网络维护工程师工资多少聊城哪里做优化网站
  • 网站开发用什么字体查询域名备案
  • 济南品牌网站建设公司网站单个页面紧张搜索引擎蜘蛛
  • 公司需要一个简单的网站包头网站建设奥北
  • 怎么制作网站导航页新手做网站详细步骤
  • 自己个人网站后台怎么做wordpress多程序用户同步
  • 赣州网联科技有限公司wordpress安装后优化
  • 二手书的网站建设做设计在哪个网站找图片大全
  • 网站seo设计北京市建设投标网站
  • 承德做网站设计的网络推广主要内容