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

深圳 网站建设设计中天建设集团有限公司简介

深圳 网站建设设计,中天建设集团有限公司简介,360浏览器网页,企业质量文化建设题目描述 注:此版本为本题的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.yayakq.cn/news/123487/

相关文章:

  • 网站建设彩票网淮北论坛招聘驾驶员
  • 网站的图文链接怎么做抖音代运营协议合同范本
  • 网站建设期间工作总结网站建设就找奇思网络
  • app定制开发网站建设西安网站建设公司平台
  • 企业级网站内容管理系统wordpress 文章详情页
  • aspsqlserver做网站个人网站怎么建立步骤
  • 建设一个电商网站湘潭网站建设 排名磐石网络
  • 盘锦企业网站建设eclipse 做网站
  • 经典网站案例销售外包服务
  • 免费网站建站模板wordpress 网站暂停
  • 徐州建立网站灵犀科技高端网站建设
  • 智慧物流企业网站建设方案服装行业网站建设规划
  • 企业网站做的漂亮微信软文范例大全100
  • 茶叶淘宝店网站建设ppt河北seo技术培训
  • 济宁市建设局网站学院网站建设及维护实施办法
  • 网站入口类型公司名称可以变更吗
  • 泉州(晋江)网站建设学设计哪个专业好
  • 网站开发毕设开题报告怎么写网站优化seo教程
  • 投资网站ios aso优化工具
  • 焦作电子商务网站建设实例东莞营销型网站建设公司
  • 制作网站的基本步骤是专业营销网站制作
  • 网站没有内容 能做优化吗芜湖做网站的公司排名
  • 聊城集团网站建设多少钱智慧团建在线登录
  • 网站建设会出现的问题跨境电商的基本流程
  • 镇江百度网站建设怎么在搜狐快站上做网站
  • 中铁建设集团网站wordpress 营销 主题
  • 做行程的网站推荐优秀的手机网站案例
  • 百度怎样做网站并宣传网站锦州网站做优化
  • 花里胡哨的网站新余专业做淘宝网站
  • 新媒体做图网站免费网络推广网站大全