1257 背包问题 V3(二分)
1257 背包问题 V3
3 秒 131,072 KB 80 分 5 级题
题意 :
从n个物品中选出k个,使单位体积价值最大
思路:
一开始正面想,试过很多种,排序什么的、、总是结果不对,最后想到二分答案
二分的规则是使index的前接近0即可

ps:blocks[i].w物体的价值 block[i].p物体的体积 p二分答案
假设p是我们要的答案,那么block[i].p*p为block[i]应该占有的价值
blocks[i].w - block[i].p * p 为现在与目标价值的差
这个差约小说明越接近答案,根据这一位进行排序,只要前k个。记录当前总体积和总价值即可。
import java.util.Arrays;
import java.util.Scanner;
public class Main {
static int n, k;
static int ansA = 0, tA = 0;
static int ansB = 0, tB = 0;
static Block[] blocks = null;
public static void main(String[] args) {
Scanner cin = new Scanner(System.in);
n = cin.nextInt();
k = cin.nextInt();
blocks = new Block[n];
for (int i = 0; i < n; i++) {
int a = cin.nextInt();
int b = cin.nextInt();
blocks[i] = new Block(a, b, 0);
}
cin.close();
double left = 0, right = 50000.0;
for (int i = 1; i < 100; i++) {
double mid = (left + right) / 2.0;
if (check(mid)) {
ansA = tA;ansB = tB;tA = tB = 0;
left = mid;
} else {
ansA = tA;ansB = tB;tA = tB = 0;
right = mid;
}
}
int x = gcd(ansA, ansB);
System.out.println(ansB / x + "/" + ansA / x);
}
public static boolean check(double p) {
for (int i = 0; i < n; i++) {
blocks[i].dis = 1.0 * blocks[i].w - blocks[i].p * p;
}
Arrays.sort(blocks);
double sum = 0;
for (int i = 0; i < k; i++) {
tA += blocks[i].w;
tB += blocks[i].p;
sum += blocks[i].dis;
}
if (sum > 0) return true;
return false;
}
static int gcd(int a, int b) {
return b == 0 ? a : gcd(b, a % b);
}
static class Block implements Comparable<Block> {
int w;
int p;
double dis;
public Block(int w, int p, double dis) {
this.w = w;
this.p = p;
this.dis = dis;
}
@Override
public int compareTo(Block o) {
if (dis > o.dis) return 1;
return -1;
}
}
}
1257 背包问题 V3(二分)的更多相关文章
- 51nod 1257 背包问题 V3
1257 背包问题 V3 基准时间限制:3 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 N个物品的体积为W1,W2......Wn(Wi为整数),与之相对应的价值为P1,P2.. ...
- 51nod 1257 背包问题 V3(这不是背包问题是二分)
题目链接:https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1257 题解:不能按照单位价值贪心,不然连样例都过不了 要求的 ...
- 51nod 1257 背包问题 V3(分数规划)
显然是分数规划...主要是不会求分数的形式,看了题解发现自己好傻逼QAQ 还是二分L值算出d[]降序选K个,顺便记录选择时候的p之和与w之和就可以输出分数形式了... #include<iost ...
- 1257 背包问题 V3——分数规划
N个物品的体积为W1,W2......Wn(Wi为整数),与之相对应的价值为P1,P2......Pn(Pi为整数),从中选出K件物品(K <= N),使得单位体积的价值最大. Input 第1 ...
- 51nod1257 背包问题 V3
分数规划经典.开始精度1e-3/1e-4都不行,1e-5就A了 #include<cstdio> #include<cstring> #include<cctype> ...
- 51nod——1086、1257背包问题V2(多重背包二进制拆分转01) V3(分数规划+二分贪心)
V3其实和dp关系不大,思想挂标题上了,丑陋的代码不想放了.
- 51nod 1257 01分数规划/二分
http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1257 1257 背包问题 V3 基准时间限制:3 秒 空间限制:1310 ...
- hdu 1025LIS思路同1257 二分求LIS
题目: Constructing Roads In JGShining's Kingdom Time Limit: 2000/1000 MS (Java/Others) Memory Limit ...
- CSU OJ PID=1514: Packs 超大背包问题,折半枚举+二分查找。
1514: Packs Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 61 Solved: 4[Submit][Status][Web Board] ...
随机推荐
- HDU 2914 Triangle (Fibnacci 数)
题意:给你一个长度为 n 的木棒,求至少拿掉几根使得剩余的木棒构成不了三角形. 析:为了保证不形成三角形,所以保证两边之和等于最大边是最优,这不就是Fibnacci 数么,由于 n 很小,if-els ...
- ASP.NET Core MVC 打造一个简单的图书馆管理系统 (修正版)(四)图书信息的增删改查
前言: 本系列文章主要为我之前所学知识的一次微小的实践,以我学校图书馆管理系统为雏形所作. 本系列文章主要参考资料: 微软文档:https://docs.microsoft.com/zh-cn/asp ...
- Ruby String类
String类 更新: 2017/06/10 更新: 2017/06/23 puts()要空格可以直接不加参数 更新: 2017/08/17 增加rails引入的titleize 更新: 2017/1 ...
- 【性能测试】服务器资源监测工具sar安装
[root@yyy ~]# sar Cannot open /var/log/sa/sa19: No such file or directory 在Linux系统中,运行sar命令,发现无法执行: ...
- HDU1452:Happy 2004(积性函数)(因子和)
题意 给出\(x\),求\(2004^x\)的所有因子和 分析 \(2004=2*2*3*167\) 则\(2004^x\)=\(2^{2x}*3^x*167^x\) s[\(2004^x\)]=s[ ...
- 关于浮动与清浮动 float
浮动常见的几种属性值 float {left; right; none; } 主要是定义元素朝哪个方向浮动: 元素浮动后的特性 在一行显示,父级的宽度放不下,自己折行: 支持宽高等样式: 不设置 ...
- python爬虫爬取腾讯招聘信息 (静态爬虫)
环境: windows7,python3.4 代码:(亲测可正常执行) import requests from bs4 import BeautifulSoup from math import c ...
- c语言程序设计案例教程(第2版)笔记(六)—字符串处理实例
字符串处理 功能描述:从键盘输入一个文本行后,为用户提供菜单选择,实现字符串一些操作——显示文本行.查找并替换指定子串.删除指定子串.统计指定子串数目. 实现代码: #include<stdio ...
- F - Function
Bryce1010模板 先找到数组A中的循环节,再找到数组B中的循环节,如果B中的循环节是A中循环节的循环因子,说明可以配对,结果累积起来. #include<bits/stdc++.h> ...
- 题解报告:hdu 2087 剪花布条(KMP入门)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2087 Problem Description 一块花布条,里面有些图案,另有一块直接可用的小饰条,里面 ...