基本0--1 分?jǐn)?shù)規(guī)劃題 poj -- 2976

題意:
給定n個(gè)二元數(shù),選取n-k個(gè)二元組合,使得sigma(a[i])/sigma(b[i])最大.
思路:
所以這就是最裸的0-1分?jǐn)?shù)規(guī)劃題,直接上模板,注意讀入時(shí)不要用cin,應(yīng)該用scanf,否則會(huì)超時(shí),我也不知道呀.

#include<cstdio>
#include<cmath>
#include<algorithm>
#include<iostream>
#include<cstring>
#include<set>
#include<queue>
#include<functional>
#include<vector>
#include<stack>
#include<map>
#include<cstdlib>
#define CLR(x) memset(x,0,sizeof(x))
#define ll long long int
#define PI acos(-1.0)
#define db double
#define mod 1000000007
using namespace std;
const int maxn=1e6;
const db eps=1e-7;
const int inf=1e9;
const ll INF=1e15;
db a[1005],b[1005],c[1005];
int main()
{
    int n,k;
    while(scanf("%d %d",&n,&k)!=EOF){
        CLR(c);
        if(n==0 && k==0)
            break;
        for(int i=0;i<n;i++)
            scanf("%lf",&a[i]);
        for(int i=0;i<n;i++)
            scanf("%lf",&b[i]);

        db l=0.0;
        db r=10.0;   //二分的范圍你可以試著確定,根據(jù)題意來(lái).這里題目中時(shí)保證了分母比分子大,
                     //所以答案應(yīng)該時(shí)不會(huì)超過(guò)1的.(當(dāng)然大點(diǎn)也行)
        db mid;
        while(r-l>eps){
            mid = (r+l)/2.0;
            /*cout << l << " " << r << endl;
            cout << mid << endl;*/
            for(int i=0;i<n;i++)
                c[i]= a[i]-mid*b[i];
            sort(c,c+n);
            db sum=0;
            for(int i=k;i<n;i++)
                sum+=c[i];

            if(sum > 0)   //目的是使sum不斷逼近0.所以大于0時(shí)就要減小sum,故L右移,就可以把
                          //sum減小.因?yàn)楦鶕?jù)推論,當(dāng)sum越接近0時(shí),答案越最優(yōu).
                l=mid;
            else
                r=mid;
        }
        printf("%.0f\n",mid*100);
    }
}
/*
3 1
5 0 2
5 1 6
4 2
1 2 7 9
5 6 7 9
0 0
*/

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末菲驴,一起剝皮案震驚了整個(gè)濱河市移袍,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌拔创,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,198評(píng)論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件击碗,死亡現(xiàn)場(chǎng)離奇詭異客燕,居然都是意外死亡混槐,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,334評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門歼跟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)和媳,“玉大人,你說(shuō)我怎么就攤上這事哈街×敉” “怎么了?”我有些...
    開封第一講書人閱讀 167,643評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵骚秦,是天一觀的道長(zhǎng)她倘。 經(jīng)常有香客問(wèn)我,道長(zhǎng)作箍,這世上最難降的妖魔是什么硬梁? 我笑而不...
    開封第一講書人閱讀 59,495評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮胞得,結(jié)果婚禮上荧止,老公的妹妹穿的比我還像新娘。我一直安慰自己阶剑,他們只是感情好跃巡,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,502評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著牧愁,像睡著了一般素邪。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上猪半,一...
    開封第一講書人閱讀 52,156評(píng)論 1 308
  • 那天兔朦,我揣著相機(jī)與錄音,去河邊找鬼办龄。 笑死烘绽,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的俐填。 我是一名探鬼主播安接,決...
    沈念sama閱讀 40,743評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了盏檐?” 一聲冷哼從身側(cè)響起歇式,我...
    開封第一講書人閱讀 39,659評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎胡野,沒想到半個(gè)月后材失,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,200評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡硫豆,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,282評(píng)論 3 340
  • 正文 我和宋清朗相戀三年龙巨,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片熊响。...
    茶點(diǎn)故事閱讀 40,424評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡旨别,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出汗茄,到底是詐尸還是另有隱情秸弛,我是刑警寧澤,帶...
    沈念sama閱讀 36,107評(píng)論 5 349
  • 正文 年R本政府宣布洪碳,位于F島的核電站递览,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏瞳腌。R本人自食惡果不足惜绞铃,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,789評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望纯趋。 院中可真熱鬧憎兽,春花似錦、人聲如沸吵冒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,264評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)痹栖。三九已至亿汞,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間揪阿,已是汗流浹背疗我。 一陣腳步聲響...
    開封第一講書人閱讀 33,390評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留南捂,地道東北人吴裤。 一個(gè)月前我還...
    沈念sama閱讀 48,798評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像溺健,于是被迫代替她去往敵國(guó)和親麦牺。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,435評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容