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

云南做网站公司哪家好中国十大企业管理培训机构

云南做网站公司哪家好,中国十大企业管理培训机构,工信部个人备案网站可信吗,溧阳网站设计有依赖的背包是指多个物品变成一个复合物品(互斥),每件复合物品不要和怎么要多种可能性展开。时间复杂度O(物品个数 * 背包容量),额外空间复杂度O(背包容量)。 下面通过题目加深理解。 题目一 测试链接:[NOIP2006 提…

有依赖的背包是指多个物品变成一个复合物品(互斥),每件复合物品不要和怎么要多种可能性展开。时间复杂度O(物品个数 * 背包容量),额外空间复杂度O(背包容量)。

下面通过题目加深理解。

题目一

测试链接:[NOIP2006 提高组] 金明的预算方案 - 洛谷

分析:对于这道题,可以参考01背包是对每个物品进行可能性的展开,有依赖的背包是对主件进行可能性的展开,所以可能性就比01背包的展开多。对于一个没有附件的主件可能性的展开,就是01背包的展开,即选或不选主件。对于有一个附件的主件可能性的展开,就有三种,选主件、不选主件、主件和附件一起选。对于有两个附件的主件可能性的展开,就有五种,选主件、不选主件、主件和第一个附件一起选、主件和第二个附件一起选、主件和两个附件一起选。对于输入,代码中采用了几个数组结构存储信息,cost数组存储花费代价,value数组存储收益,king数组存储是否是主件,fans数组存储主件有多少个附件,follows数组存储每个主件拥有的附件。下面代码采用计划搜索,并没有去做空间压缩,代码如下。

#include <iostream>
#include <vector>
using namespace std;
int n, m;
int cost[61];
int value[61];
bool king[61];
int fans[61] = {0};
vector<vector<int>> follows;
int dp[61][32001];
int f(int index, int money){if(index == m+1){return 0;}if(dp[index][money] != -1){return dp[index][money];}if(!king[index]){return f(index+1, money);}int ans = f(index+1, money);if(money - cost[index] >= 0){ans = ans > f(index+1, money-cost[index]) + value[index] ?ans : f(index+1, money-cost[index]) + value[index];}if(fans[index] >= 1 && money - cost[index] - cost[follows[index][0]] >= 0){ans = ans > f(index+1, money-cost[index]-cost[follows[index][0]]) + value[index] + value[follows[index][0]] ?ans : f(index+1, money-cost[index]-cost[follows[index][0]]) + value[index] + value[follows[index][0]];}if(fans[index] == 2){if(money - cost[index] - cost[follows[index][1]] >= 0){ans = ans > f(index+1, money-cost[index]-cost[follows[index][1]]) + value[index] + value[follows[index][1]] ?ans : f(index+1, money-cost[index]-cost[follows[index][1]]) + value[index] + value[follows[index][1]];}if(money - cost[index] - cost[follows[index][0]] - cost[follows[index][1]] >= 0){ans = ans > f(index+1, money-cost[index]-cost[follows[index][0]]-cost[follows[index][1]]) + value[index] + value[follows[index][0]] + value[follows[index][1]] ?ans : f(index+1, money-cost[index]-cost[follows[index][0]]-cost[follows[index][1]]) + value[index] + value[follows[index][0]] + value[follows[index][1]];}}dp[index][money] = ans;return ans;
}
int main(void){int v, p, q;scanf("%d%d", &n, &m);vector<int> temp;for(int i = 0;i <= m;++i){follows.push_back(temp);}for(int i = 1;i <= m;++i){scanf("%d%d%d", &v, &p, &q);cost[i] = v;value[i] = v * p;if(q != 0){king[i] = false;fans[q]++;follows[q].push_back(i);}else{king[i] = true;}}for(int i = 1;i < 61;++i){for(int j = 1;j < 32001;++j){dp[i][j] = -1;}}printf("%d", f(1, n));return 0;
}

http://www.hrbkazy.com/news/43124.html

相关文章:

  • 做淘口令网站500个游戏推广群
  • 中国国际贸易网整站优化深圳
  • 机械加工网企业名录廊坊关键词优化排名
  • 海口网站建设策划方案许昌正规网站优化公司
  • 小程序 网站建设 app 开发哪有网页设计公司
  • java做网站的多么竞价点击软件工具
  • 青县做网站价格站长工具seo综合查询访问
  • 做网站建设销售辛苦吗网络推广与营销
  • 网站建设全程揭秘seo优化快速排名
  • 做影视网站不备案优秀的软文广告案例
  • wordpress英文站群网站搜索排名优化
  • 国外做医疗器械b2b网站google搜索关键词热度
  • 江苏省教育现代化建设水平监测网站网络优化的基本方法
  • 动态web网站怎么做网络推广的方式有哪些?
  • 成都高新区网站建设怎么成为百度推广代理商
  • 不花钱的做网站sem培训学校
  • wap网站 教程百度一下首页网址
  • 怎么做QQ信任网站百度营销推广登录平台
  • 做推广网站需要商标吗seo如何快速排名百度首页
  • 网站优化seo是什么芒果视频怎样下载到本地
  • 广告投放网站平台如何免费推广网站
  • 深圳网络公司接单河南网站关键词优化
  • 物业管理 网站开发百度关键词怎么排名
  • 简单的企业网站制作网络广告
  • 合肥哪里有做网站搜索引擎有哪些技巧
  • 装修公司展厅布置方案推广优化方案
  • 新闻类的网站如何做优化、企业文化理念
  • 专业创建网站百度广告开户流程
  • 银川如何做百度的网站百度快速排名用什
  • 桂林创新大厦网站百度中心