[POJ 2976]Dropping tests(0-1分数规划)

[POJ 2976]Dropping tests(0-1分数规划)

大家好,又见面了,我是全栈君。

  1. 题目地址:http://poj.org/problem?

    id=2976

  2. 题目大意:给你n个物品的a值和b值,要你从中丢掉k个(或者说选择n-k个)物品,使得剩下的物品的[POJ 2976]Dropping tests(0-1分数规划)最大
  3. 题目思路(以下思路转自http://blog.csdn.net/neofung/article/details/7649603):

    我们能够看看例如以下推导

    [POJ 2976]Dropping tests(0-1分数规划)

    题目就变成了二分检索r

  4. 代码:

    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #include <algorithm>
    #include <cmath>
    
    #define MAXN 1010
    #define EPS (1e-6)
    #define INF 0x3f3f3f3f
    
    using namespace std;
    
    double w[MAXN],v[MAXN];
    int n,k;
    double value[MAXN];
    
    bool check(double x) //推断平均值x是否可取
    {
    	double sum=0;
    	for(int i=1;i<=n;i++)
    		value[i]=v[i]-x*w[i];
    	sort(value+1,value+n+1); //贪心排序,从大到小选取k个value[i],且这k个value的和必须不小于0
    	for(int i=n;i>=n-k+1;i--)
    		sum+=value[i];
    	return sum>=0;
    }
    
    int main()
    {
    	while(scanf("%d%d",&n,&k)!=EOF&&!(n==0&&k==0))
    	{
    	    k=n-k;
    		for(int i=1;i<=n;i++)
    			scanf("%lf",&v[i]);
    		for(int i=1;i<=n;i++)
    			scanf("%lf",&w[i]);
    		double lowerBound=0,upperBound=INF; //二分这个平均值
    		while(fabs(upperBound-lowerBound)>EPS)
    		{
    			double mid=(lowerBound+upperBound)/2;
    			if(check(mid)) lowerBound=mid;
    			else upperBound=mid;
    		}
    		printf("%.f\n",100*upperBound);
    	}
    	return 0;
    }
    


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/115619.html原文链接:https://javaforall.net

(0)
上一篇 2022年2月1日 下午9:00
下一篇 2022年2月1日 下午10:00


相关推荐

  • jxls能把html转成excel吗,如何用XLSTransformer生成excel文件?jxls的使用方法

    jxls能把html转成excel吗,如何用XLSTransformer生成excel文件?jxls的使用方法jxls的使用方法:1)声明一个XLSTransformer对象,生成方式就是使用new操作符XLSTransformertransformer=newXLSTransformer();2)得到Template的FIle:StringxlsTemplateFileName=this.getClass().getClassLoader().getResource(“template.x…

    2022年7月24日
    8
  • ssh 提示Connection closed by * 的解决方案

    ssh 提示Connection closed by * 的解决方案ssh 提示 Connectioncl 的解决方案

    2026年3月26日
    3
  • IntelliJ IDEA单元测试入门

    IntelliJ IDEA单元测试入门参考文章地址地址 JUnit4 单元测试入门教程 IDEA 单元测试及代码覆盖率 IDEA 添加 jar 包的三种方式本文按以下顺序讲解 JUnit4 的使用下载 jar 包单元测试初体验自动生成测试类执行顺序 Test 的属性

    2026年3月19日
    1
  • windows10更新报错0x80240fff_windows10易升有什么用

    windows10更新报错0x80240fff_windows10易升有什么用win10更新错误0x8000ffff处理方法:1.同时按下Windows键和R键,打开运行,输入services.msc;2.找到WindowsUpdate服务项,右键选择禁用;3.打开c:\windows\SoftwareDistribution\datastore,删除datastore和和Download两个文件夹下的所有文件;4.按照1和2的步骤开启WindowsUpdate服务,重新检查更新;如果不行用下法试试:右键点击开始——命令提示符(管理员),输入以下命令尝试修复。dism

    2026年3月9日
    4
  • Java学习日记:UI篇(6)–谢尔宾斯基地毯图

    Java学习日记:UI篇(6)–谢尔宾斯基地毯图Java 学习日记 UI 篇 6 谢尔宾斯基地毯图引言 谢尔宾斯基地毯是数学家谢尔宾斯基提出的一个分形图形 谢尔宾斯基地毯和谢尔宾斯基三角形基本类似 不同之处在于谢尔宾斯基地毯采用的是正方形进行分形构造 而谢尔宾斯基三角形采用的等边三角形进行分形构造 谢尔宾斯基地毯和它本身的一部分完全相似 减掉一块会破坏自相似性 来自百度百科 是不是还不知道它是啥东西 没事 来张图看看 有密集恐惧症者慎入 思路 nbsp nbsp nbsp nbsp nbsp nbsp nbsp

    2026年3月18日
    2
  • Jenkins(2)docker容器中安装python3[通俗易懂]

    Jenkins(2)docker容器中安装python3[通俗易懂]前言使用docker安装jenkins环境,jenkins构建的workspace目录默认是在容器里面构建的,如果我们想执行python3的代码,需进容器内部安装python3的环境。进jenki

    2022年8月6日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号