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

中国做的比较好的网站有哪些百度视频广告怎么投放

中国做的比较好的网站有哪些,百度视频广告怎么投放,做违法网站会怎么样,网站建设有什么好处引言 多重背包,相对于01背包来说,多重背包是每个物品会有相应的个数,最多可以选那么多个,因而对于朴素多重背包,需要在01背包的基础上,再加一层物品的循环 朴素多重背包例题 P2347 [NOIP1996 提高组] 砝…

引言

多重背包,相对于01背包来说,多重背包是每个物品会有相应的个数,最多可以选那么多个,因而对于朴素多重背包,需要在01背包的基础上,再加一层物品的循环

朴素多重背包例题

P2347 [NOIP1996 提高组] 砝码称重

题意,就是说有六种砝码每种砝码有自己的个数,问你能达到的重量搭配是多少

题解:标准的多重背包,我们可以用dp[ j ]去表示 j 重量能否达到,如果能达到就是1,如果不能打达到就是0,最后遍历一遍dp数组去判断有多少个1即可

#include<bits/stdc++.h>
using namespace std;
int a[7];
int w[7]={0,1,2,3,5,10,20};
int dp[1050];int main()
{for(int i=1;i<=6;i++)cin>>a[i];dp[0]=1;for(int i=1;i<=6;i++){for(int j=1050;j>=0;j--){for(int k=0;k<=a[i];k++)//遍历第i个物品选的个数{if(dp[j]==1){dp[j+k*w[i]]=1;}}}}int sum=0;for(int i=1;i<=1000;i++)if(dp[i]!=0)sum++;cout<<"Total="<<sum;return 0;
}

 P6771 [USACO05MAR] Space Elevator 太空电梯

题意,就是说给你n中方块,每个方块有自己的高度,和最大搭建的限制(在某个高度以后不能用这种方块),还有方块的数量

思路:这是一个变式,我们需要将其组装成一个结构体,然后对a数组进行排序,从小到大进行排序,然后进行多重背包即可

#include<bits/stdc++.h>
using namespace std;
int n;
struct node{int h;int limit;int num;
}a[405];
int dp[40005];//能否达到高度为j,能达到为1,不能为0bool cmp(node a,node b)
{return a.limit<b.limit;
}int main()
{cin>>n;for(int i=1;i<=n;i++)cin>>a[i].h>>a[i].limit>>a[i].num;dp[0]=1;sort(a+1,a+1+n,cmp);for(int i=1;i<=n;i++){for(int j=a[i].limit;j>=0;j--){for(int k=0;k<=a[i].num&&j+k*a[i].h<=a[i].limit;k++){if(dp[j]==1){dp[j+k*a[i].h]=1;}}}}for(int i=a[n].limit;i>=0;i--){if(dp[i]==1){cout<<i;return 0;}}return 0;
} 

 P5365 [SNOI2017] 英雄联盟

 题意:有n个英雄,每个英雄有k个皮肤,对于一个英雄的所有皮肤都是一个价格c,但是我又想要m中搭配,正常的求法是算出m个搭配至少要多少钱,但是这题m的数据太大了,只能通过对于一定的钱,其搭配数是多少

思路:dp数组表示的是对于j元,总共有多少的搭配数,然后判断这个搭配数是否大于m从前向后遍历,找到第一个大于m种搭配的位置,那个下标就是最小花费

//英雄联盟 
//这题皮肤搭配数量太大了,肯定不能当数组,要换成j个q币能搞得最大皮肤搭配 
#include<bits/stdc++.h>
using namespace std;
#define int long long
int n,m;
int num[135];
int w[135];
int dp[270005];
signed main()
{cin>>n>>m;int sum=0;//计算总金额 for(int i=1;i<=n;i++){cin>>num[i];}for(int i=1;i<=n;i++){cin>>w[i];sum+=num[i]*w[i];}dp[0]=1;for(int i=1;i<=n;i++){for(int j=sum;j>=0;j--){for(int k=0;k<=num[i]&&k*w[i]<=j;k++){dp[j]=max(dp[j],dp[j-k*w[i]]*k);}}}for(int i=1;i<=sum;i++){if(dp[i]>=m){cout<<i;return 0;}}return 0;
}

二进制优化

用到的是二进制拆分思想

比如说对于50这个数,我们用二进制拆分可以分为 1,2,4,8,16,19,这五个数,我们这五个数搭配可以组成50以内的所有自然数,所以我们二进制优化也是通过拆分每个物品的个数从而降低时间复杂度,从而形成完全的01背包问题

二进制优化例题

P1776 宝物筛选

一看这道题,如果用正常的多重背包,时间复杂度为100*40000*100000肯定会爆数据的,所以我们要用二进制优化,将时间复杂度变为4e6*log2(100000),这样就大大降低的时间的复杂度

将物品数量进行二进制拆分

#include<bits/stdc++.h>
using namespace std;
#define int long long
int n,m;
int v[1405];
int w[1405];
int dp[40005];signed main()
{cin>>n>>m;int vv,ww,mm;int cnt=0;for(int i=1;i<=n;i++){cin>>vv>>ww>>mm;for(int j=1;j<=mm;j<<=1){cnt++;v[cnt]=j*vv;w[cnt]=j*ww;mm-=j;}if(mm){cnt++;v[cnt]=mm*vv;w[cnt]=mm*ww;}}for(int i=1;i<=cnt;i++){for(int j=m;j>=w[i];j--){dp[j]=max(dp[j],dp[j-w[i]]+v[i]);}}cout<<dp[m];return 0;
}

 

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

相关文章:

  • 对于给不良网站发律师函如何做网站优化技术
  • 中小型网站建设哪家好培训机构需要什么资质
  • 青岛城市建设委员会网站深圳百度公司地址在哪里
  • 信阳网站建设黄冈网站推广软件有哪些
  • wordpress外贸建站百度pc网页版入口
  • 登陆美国网站做报价单 网速慢下载百度app最新版到桌面
  • 可以接项目做的网站服务器域名怎么注册
  • 政府网站建设和管理办法网站的优化从哪里进行
  • 公司注销需要多少钱费用?百度seo是啥
  • jsp企业网站开发毕业论文西安网站建设维护
  • 汉中商城网站建设品牌推广渠道有哪些
  • 郑州网站策划个人发布信息免费推广平台
  • 网页设计分为哪些板块好的seo公司营销网
  • 江苏建设人才网站it培训学校
  • 哪些网站可以做问卷调查赚钱百度搜图
  • 网站接入查询销售清单软件永久免费版
  • 用wordpress复制一个网站搜索引擎入口大全
  • 公司网站做门户备案关键词排名网站
  • 通过模板做网站电商网站订烟平台官网
  • 做产品推广哪个网站好seo推广价格
  • 濮阳微信网站开发免费使用seo软件
  • 网页网站开发公司网络营销网站设计
  • 武汉网站建设公司 排名如何免费推广网站
  • 判断网站cmsqq刷赞网站推广快速
  • 网站建设 大纲新乡seo公司
  • 泉州厦门网站建设公司天津企业seo
  • ui设计培训课程seo点击排名器
  • ecs服务器 做网站营销推广计划书
  • 武汉网站建设报价明细表深圳网络推广渠道
  • 电子商务网站功能特点搜索引擎营销例子