poj2976:dropping tests(0/1分数规划)
来源:互联网 发布:中考倒计时软件下载 编辑:程序博客网 时间:2024/06/05 00:54
Description
In a certain course, you take n tests. If you get ai out of bi questions correct on test i, your cumulative average is defined to be.
Given your test scores and a positive integer k, determine how high you can make your cumulative average if you are allowed to drop any k of your test scores.
Suppose you take 3 tests with scores of 5/5, 0/1, and 2/6. Without dropping any tests, your cumulative average is . However, if you drop the third test, your cumulative average becomes .
题意:
给两个数组a[i],b[i],求r=
0-1分数规划
一、分数规划
分数规划的一般形式:
其中,解向量x在解空间S内,a(x),b(x)都是连续的实值函数。
一般解决分数规划问题的实用方法为参数搜索法,即对答案进行猜测,再验证该猜测值,的最优性,将最优化问题转化为判定性问题或其他更容易求解的最优化问题。由于分数规划 模型的特殊性,使得能够构造另外一个由猜测值 作为自变量的相关问题,且该问题的解满足一定的单调性,或其他的可以减小参数搜索范围的性质,从而逼近答案。
假设
由上面的形式构造一个新函数g(x):
这个函数是一个非分式的规划。先来看看它本身的性质:
单调性:
证明:设解向量
最后一步说明
有了单调性,就意味着我们可以采用二分搜索的方法来逼近答案。但我们还不知道我们所求的目标是什么,下面考察构造出的新函数与原目标函数的最优解关系:
Dinkelbach定理:设
证明:必要性:
对于
然而
充分性:
若存在一个解x使得
反证法。反设存在一个解
这时
由上面的性质及定理容易推得:
有了该推论我们就可以对最优解进行二分查找,每次需要计算的是一个新的非分数规 划,这就将原问题简化了,以便我们能设计出其他有效的算法解决这个问题。算法的复杂度 是二分迭代的次数与每次解决
二、0/1分数规划
分数规划的一个特例是0-1分数规划,就是其解向量满足
解决0-1分数规划与普通的分数规划一样,也可以采用二分搜索,构建新的规划函数求 解的算法。
例如:给定1个二元组
题解:
二分答案
且任意的
回到原问题中,我们将每个二元组的价值设为
#include<iostream>#include<cstdio>#include<cstdlib>#include<cstring>#include<string>#include<algorithm>#include<cmath>using namespace std;const int Maxn=1050;const double eps=1e-7;inline int read(){ char ch=getchar();int i=0,f=1; while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();} while(isdigit(ch)){i=(i<<1)+(i<<3)+ch-'0';ch=getchar();} return i*f;}int n,k;double a[Maxn],b[Maxn],c[Maxn];inline bool check(double r){ for(int i=1;i<=n;i++)c[i]=a[i]-r*b[i]; sort(c+1,c+n+1); double sum=0; for(int i=k+1;i<=n;i++) { sum+=c[i]; } return sum>=0;}int main(){ while(1) { n=read(),k=read(); if(!n&&!k)break; for(int i=1;i<=n;i++)a[i]=read(); for(int i=1;i<=n;i++)b[i]=read(); double l=0,r=1.0; while(r-l>eps) { double mid=(l+r)*1.0/2.0; if(check(mid))l=mid; else r=mid; } printf("%.0f\n",l*100); } return 0;}
- 0/1分数规划 【POJ2976】Dropping tests
- poj2976--Dropping tests(0-1分数规划)
- poj2976:dropping tests(0/1分数规划)
- [POJ2976]Dropping tests(01分数规划)
- POJ2976 Dropping tests (分数规划)
- [POJ2976][分数规划]Dropping tests[水题]
- poj2976 Dropping tests 【01分数规划】
- [POJ2976]Dropping tests 01分数规划
- 【POJ2976】Dropping tests 01分数规划
- 【分数规划】POJ2976[Dropping tests]题解
- POJ2976-01分数规划&二分-Dropping tests
- POJ2976:Dropping tests(二分法)
- [POJ 2976]Dropping tests(0-1分数规划)
- poj 2976 Dropping tests 【0-1分数规划】
- poj2976 0-1分数规划
- 【POJ2976】0-1分数规划
- (最大化平均值)poj2976,Dropping tests
- POJ2976 Dropping tests 最大化平均值(二分)
- The platform command has been renamed. To find out more, run: ionic cordova platform --help
- openalpr在windows10 x64 vs2015编译
- "less is more",用"less”命令查看linux文本文件
- STC15F104E (8脚单片机)实现蓝牙串口控制舵机转向
- sublime text 安装教程与常用插件安装与卸载方法
- poj2976:dropping tests(0/1分数规划)
- properties文件工具类
- 未在本地计算机上注册“microsoft.ACE.oledb.12.0”提供程序解决办法
- 首个区块链标准《区块链 参考架构》正式发布
- 安卓应用启动时黑屏和白屏的原因及解决办法
- Java 内存分配全面浅析(转载)
- JAVA生成验证码
- poj3904 Sky Code —— 唯一分解定理 + 容斥原理 + 组合
- Android中的广播Broadcast