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

dreamweaver做的网站百度直播平台

dreamweaver做的网站,百度直播平台,学做视频t的网站,重庆网站建设设计公司哪家好题目描述 注:此版本为本题的hard(困难版),与easy(简单版)唯一的不同之处只有数据范围。 小苯有一个容量为 k 的背包,现在有 n 个物品,每个物品有一个体积 v 和价值 w&#xff0…

题目描述 

注:此版本为本题的hard(困难版),与easy(简单版)唯一的不同之处只有数据范围。
 

小苯有一个容量为 k 的背包,现在有 n 个物品,每个物品有一个体积 v 和价值 w,他想知道在体积不超过 k 的前提下,他最多能装价值为多少的物品。

本问题中,物品的总体积定义为所装物品的体积的 &&(按位与),总价值也定义为所装物品的价值的 &&(按位与)。

(如果不选物品,则价值为 0,所占体积也为 0。)

输入描述:

输入包含 n+1 行。
第一行两个正整数  n,k (1≤n≤2×105,0≤k≤109),分别表示物品个数和背包容量。
加下来 n 行,每行两个正整数 vi​,wi​ (0≤vi​,wi​≤109),表示每个物品的体积和价值。

输出描述:

输出包含一行一个整数,表示能装的最大价值。

示例1

输入

复制

3 1
7 3
10 7
9 6

输出

复制

2

说明

选择第一个和第三个物品。
体积为:7 & 9=17 & 9=1。
价值为:3 & 6=23 & 6=2。可以证明不存在比 22 更大的价值。

示例2

输入

复制

3 2
7 3
10 7
9 6

输出

复制

3

说明

选第一个和第二个物品。

思路:
由于体积和价值选的越多越小,一般背包思路不行

本题采用&运算,反向思路求最多价值,即每一位尽量为1

代码:

#include<bits/stdc++.h>
using namespace std;
int main(){int n,k;cin>>n>>k;int v[n+1],w[n+1];int ans=0;for(int i=1;i<=n;++i)cin>>v[i]>>w[i];for(int i=30;i>=0;i--){//从高位开始枚举,确保价值最高int num=(1L<<30)-1;//初始化最大体积,由于&运算,选的越多体积越小int g=ans|(1<<i);//将第i位变1,继承其他位置for(int j=1;j<=n;++j){if((g&w[j])==g)num=num&v[j];//第i位是1就选}if(num<=k){//体积不超过kans=g;//ans肯定是越来越大的,每次满足第i为变1}}cout<<ans<<endl;
}

http://www.15wanjia.com/news/6035.html

相关文章:

  • 广州网站改版 网站建设网店推广常用的方法
  • 承德网站建设服务网络营销公司是做什么的
  • 住房和城乡建设部网站八大员网站的收录情况怎么查
  • 网站收录怎么弄哪些平台可以发布软文
  • 网站上传工具有什么武汉网站建设公司
  • 怎么做网站收录的关键词专业做网站建设的公司
  • 网站开发建设总结新塘网站seo优化
  • 外贸英文商城网站建设优化教程
  • 太原网站建设王道下拉惠优秀营销软文范例800字
  • 无线网络优化是做什么的seo技术快速网站排名
  • 公司做网站价格网站流量统计系统
  • 做网站客户需要提供的资料成都品牌推广
  • 网站平台需要做无形资产吗 怎么做6怎么做好营销推广
  • php是用来做网站的吗成人本科
  • 沈阳网站制作费用什么是seo营销
  • 网站验证码出不来百度网盘官网网页版
  • 网站视频上传怎么做公司搭建网站
  • 镇江发布的最新消息网站seo优化怎么做
  • 平面设计提高审美网站seo诊断工具
  • 一般做网站上传的图片大小长沙网站seo优化排名
  • 做网站是用什么语言推广学院seo教程
  • css网站布局原码线上推广的三种方式
  • 海南日报官网seo软件定制
  • 没有网站怎么做cpa怎么优化自己网站的关键词
  • 做营销网站那个好公司宣传网页怎么做
  • 做301网站打不开百度点击率排名有效果吗
  • 建设银行网站查询密码是什么网络销售公司怎么运作
  • 创建网站的网站网络营销师是做什么的
  • 宁波妇科医生seo排名优化点击软件有哪些
  • 友情链接是在网站后台做吗网站运营师