1257 背包问题 V3

3 秒 131,072 KB 80 分 5 级题

题意 :

从n个物品中选出k个,使单位体积价值最大

思路:

一开始正面想,试过很多种,排序什么的、、总是结果不对,最后想到二分答案


二分的规则是使index的前接近0即可

ps:blocks[i].w物体的价值 block[i].p物体的体积 p二分答案

假设p是我们要的答案,那么block[i].p*pblock[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(二分)的更多相关文章

  1. 51nod 1257 背包问题 V3

    1257 背包问题 V3 基准时间限制:3 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 N个物品的体积为W1,W2......Wn(Wi为整数),与之相对应的价值为P1,P2.. ...

  2. 51nod 1257 背包问题 V3(这不是背包问题是二分)

    题目链接:https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1257 题解:不能按照单位价值贪心,不然连样例都过不了 要求的 ...

  3. 51nod 1257 背包问题 V3(分数规划)

    显然是分数规划...主要是不会求分数的形式,看了题解发现自己好傻逼QAQ 还是二分L值算出d[]降序选K个,顺便记录选择时候的p之和与w之和就可以输出分数形式了... #include<iost ...

  4. 1257 背包问题 V3——分数规划

    N个物品的体积为W1,W2......Wn(Wi为整数),与之相对应的价值为P1,P2......Pn(Pi为整数),从中选出K件物品(K <= N),使得单位体积的价值最大. Input 第1 ...

  5. 51nod1257 背包问题 V3

    分数规划经典.开始精度1e-3/1e-4都不行,1e-5就A了 #include<cstdio> #include<cstring> #include<cctype> ...

  6. 51nod——1086、1257背包问题V2(多重背包二进制拆分转01) V3(分数规划+二分贪心)

    V3其实和dp关系不大,思想挂标题上了,丑陋的代码不想放了.

  7. 51nod 1257 01分数规划/二分

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1257 1257 背包问题 V3 基准时间限制:3 秒 空间限制:1310 ...

  8. hdu 1025LIS思路同1257 二分求LIS

    题目: Constructing Roads In JGShining's Kingdom Time Limit: 2000/1000 MS (Java/Others)    Memory Limit ...

  9. CSU OJ PID=1514: Packs 超大背包问题,折半枚举+二分查找。

    1514: Packs Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 61  Solved: 4[Submit][Status][Web Board] ...

随机推荐

  1. Ordeby then by

    先按orderby排序,再按thenby排序 return PartialView("_ClickRangeOnCategory", articles.OrderByDescend ...

  2. MYSQL自动备份策略的选择(转载)

    原文地址: http://shinepaopao.iteye.com/blog/1938568

  3. [App Store Connect帮助]八、维护您的 App(4.4)重置 App 总评分(iOS、Apple TVOS、macOS)

    当您发布新版本时,您可以重置 App 评分.您的产品页将显示一则消息,说明 App 的总评分最近已重置.此消息将一直显示,直到有足够多的顾客对新版本进行了评分且页面出现新的总评分. 评分只可以针对全球 ...

  4. JAVA中抽象类不可以实例化,却可以创建数组

    这是我定义的一个抽象类: 如果你试图创建一个对象,当然是不行的,抽象类不能用new运算符创建对象. 这是错误提示,还记得instantiate这个单词吗?在我的这篇随笔第二篇(那些JAVA程序BUG中 ...

  5. ES高级查询

    Query Content 在查询过程中,除了判断文档是否满足查询条件外,ES还会计算一个_score来标识匹配的程度,旨在判断目标文档和查询条件的匹配有多好 # POST 192.168.100.1 ...

  6. _bzoj2243 [SDOI2011]染色【树链剖分】

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2243 裸的树链剖分,最开始我保存一个线段树节点的color值时(若有多种颜色则为-1),不小 ...

  7. 尺取法 POJ 3320 Jessica's Reading Problem

    题目传送门 /* 尺取法:先求出不同知识点的总个数tot,然后以获得知识点的个数作为界限, 更新最小值 */ #include <cstdio> #include <cmath> ...

  8. 光盘安装ubuntu出现busybox-initramfs不能继续安装的终极解决方法

    我用的是Intel G45的主板,可能是板子太新的原因,kernel支持有问题 从光盘(官方寄来的光盘)安装ubuntu,出现提示: BusyBox V1.1.3 (Debian 1:1.1.3-5u ...

  9. PWA之serviceWorker应用

    1.serviceWorker介绍service worker是一段运行在浏览器后台的JavaScript脚本,在页面中注册并安装成功后,它可以拦截和处理网络请求,实现缓存资源并可在离线时响应用户的请 ...

  10. 447 Number of Boomerangs 回旋镖的数量

    给定平面上 n 对不同的点,“回旋镖” 是由点表示的元组 (i, j, k) ,其中 i 和 j 之间的距离和 i 和 k 之间的距离相等(需要考虑元组的顺序).找到所有回旋镖的数量.你可以假设 n ...