Divide and conquer:K Best(POJ 3111)

时间:2022-01-02 08:28:30

                Divide and conquer:K Best(POJ 3111)

               挑选最美的珠宝

  题目大意:挑选k个珠宝使得∑a/∑b最大,输出组合数

  最大化平均值的标准题型,二分法就好了,一定要注意范围(10e-7),如果是10e-8就会tle,10e-6就是wa

  

 #include <iostream>
#include <functional>
#include <algorithm> using namespace std;
struct _set
{
int v, w, num;
}jewels[];
struct _out_set
{
double price;
int num;
bool operator<(const _out_set &x)const
{
return price < x.price;
}
}y[];
static int s2[]; bool judge(double, const int, const int); int main(void)//最大化平均值标准题型,要求输出组合
{
int n, k;
double lb, rb, mid; while (~scanf("%d%d", &n, &k))
{
for (int i = ; i < n; i++)
{
scanf("%d%d", &jewels[i].v, &jewels[i].w);
jewels[i].num = i + ;
}
lb = ; rb = 10e++; for (; rb - lb > 10e-;)//精度起码10e-7以上,不能10e-8,不然tle
{
mid = (lb + rb) / ;
if (judge(mid, n, k))lb = mid;
else rb = mid;
}
for (int i = ; i < k; i++)
printf("%d ", s2[i]);
printf("\n");
}
return ;
} bool judge(double mid, const int n, const int k)
{
double sum = ;
for (int i = ; i < n; i++)
{
y[i].price = jewels[i].v - mid*jewels[i].w;
y[i].num = jewels[i].num;
}
sort(y, y + n);//内建排序一定要对,不然又要出错了T T for (int i = ; i < k; i++)
{
sum += y[n - i - ].price;
s2[i] = y[n - i - ].num;
}
return sum >= ;
}

  Divide and conquer:K Best(POJ 3111)

Divide and conquer:K Best(POJ 3111)的更多相关文章

  1. Divide and conquer&colon;Telephone Lines&lpar;POJ 3662&rpar;

    电话线 题目大意:一堆电话线要你接,现在有N个接口,总线已经在1端,要你想办法接到N端去,电话公司发好心免费送你几段不用拉网线,剩下的费用等于剩余最长电话线的长度,要你求出最小的费用. 这一看又是一个 ...

  2. Divide and conquer&colon;Dropping tests&lpar;POJ 2976&rpar;

    最大化平均值 题目大意:给定你n个分数,从中找出k个数,使∑a/∑b的最大值 这一题同样的也可以用二分法来做(用DP会超时,可见二分法是多么的实用呵!),大体上是这样子:假设最大的平均值是w,那么题目 ...

  3. Divide and Conquer&colon;Cable Master&lpar;POJ 1064&rpar;

    缆绳大师 题目大意,把若干线段分成K份,求最大能分多长 二分法模型,C(x)就是题干的意思,在while那里做下文章就可以了,因为这个题目没有要求长度是整数,所以我们要不断二分才行,一般50-100次 ...

  4. K Besk &lbrack;POJ 3111&rsqb;

    描述 Demy有n颗宝石.她的每个珠宝都有一些价值vi和重量wi.自从丈夫约翰在最近的金融危机爆发后,已经决定出售一些珠宝.她决定自己会保留最好的珠宝.她决定保留这样的宝石,使他们的具体价值尽可能大. ...

  5. Divide and conquer&colon;Aggressive Cows&lpar;POJ 2456&rpar;

    侵略性的牛 题目大意:C头牛最大化他们的最短距离 常规题,二分法即可 #include <iostream> #include <algorithm> #include &lt ...

  6. Divide and Conquer&colon;Monthly Expense&lpar;POJ 3273&rpar;

    Monthly Expense 题目大意:不废话,最小化最大值 还是直接套模板,不过这次要注意,是最小化最大值,而不是最大化最小值,判断的时候要注意 联动3258 #include <iostr ...

  7. Divide and Conquer&colon;River Hopscotch&lpar;POJ 3258&rpar;

     去掉石头 题目大意:一群牛在河上的石头上跳来跳去,现在问你如何通过去掉M个石头,使得牛跳过石头的最短距离变得最大? 这一题比较经典,分治法的经典,二分法可以很方便处理这个问题,我们只要明白比较函数这 ...

  8. poj 3111 K Best 最大化平均值 二分思想

    poj 3111 K Best 最大化平均值 二分思想 题目链接: http://poj.org/problem?id=3111 思路: 挑战程序竞赛书上讲的很好,下面的解释也基本来源于此书 设定条件 ...

  9. POJ 3111 K Best(01分数规划)

    K Best Time Limit: 8000MS   Memory Limit: 65536K Total Submissions: 9876   Accepted: 2535 Case Time ...

随机推荐

  1. linux 实践2&period;2 编译模块

    1.  理解模块原理 linux模块是一些可以作为独立程序来编译的函数和数据类型的集合.之所以提供模块机制,是因为Linux本身是一个单内核.单内核由于所有内容都集成在一起,效率很高,但可扩展性和可维 ...

  2. Google Volley&colon; How to send a POST request with Json data&quest;

    sonObjectRequest actuallyaccepts JSONObject as body. From http://arnab.ch/blog/2013/08/asynchronous- ...

  3. uva580Critical Mass

    递推.   用f[i]代表i个盒子的放法,设g[i]=2^n-f[i],代表i个盒子不满足条件的放法. 枚举第一个U所在的位置j.则方法有g[j-2]*(2^(i-j-2))种,j-1必须是L. 所以 ...

  4. 1&lowbar;jz2440在linux下烧写裸机程序

    常用的烧写方法有: 1.使用并口工具烧写:接线(参考百问网JZ2440V2开发板使用手册),使用oflash烧写(速度比较慢),可烧写.bin文件,从新上电观察效果.可烧写u_boot. 2.使用op ...

  5. Java双向链表实现

    public class DoublyLinkList { private class Data{ private Object obj; private Data left = null; priv ...

  6. 读取group by 之外的字段

    序号 姓名 性别 身高 1 张三 男  185 2 李四 女  161 3 王五 女  166 4 赵六 男  178 1.获取男生女生人数 select count(性别) , 性别 from 表名 ...

  7. 在ssm框架中前后台数据交互均使用json格式

    前后台数据交互均使用json. 框架ssm(spring+springmvc+mybatis) @RequestBody注解实现接收http请求的json数据,将json数据转换为java对象,注解加 ...

  8. 新版ios证书的申请

    现在IOS不再开放提供测试证书了,整理一个申请证书的流程. 1. 申请应用的id 链接地址 https://developer.apple.com/登陆开发者中心,在account界面点击红框里面得区 ...

  9. ABP框架记录

    1.先在Core项目中建立模型Models>Model.cs/ModelManager.cs 2.在Application中建立接口和具体类:IModelAppService.csModelAp ...

  10. 美人鱼 hdu 5784

    Peter has a sequence a1,a2,...,ana1,a2,...,an and he define a function on the sequence -- F(a1,a2,.. ...