青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

pku2010 Moo University - Financial Aid 二分法的高級(jí)應(yīng)用

題意大概說(shuō)下
N頭奶牛想上大學(xué),每個(gè)奶牛有一個(gè)SAT分?jǐn)?shù)和一個(gè)助學(xué)金數(shù)目。奶牛大學(xué)只能提供M個(gè)名額以及K助學(xué)金數(shù)目。求一種分配方案使得奶牛大學(xué)錄取的牛中SAT分?jǐn)?shù)在中位數(shù)上的分?jǐn)?shù)最大。
思路:
可以對(duì)奶牛的分?jǐn)?shù)排序后二分確定中位數(shù)。開(kāi)兩個(gè)數(shù)組,datas,datac,前者按照奶牛分?jǐn)?shù)排序,后者按照奶牛助學(xué)金數(shù)目排序。二分枚舉中位數(shù),然后進(jìn)行驗(yàn)證:
按照datac從低到高順序在總和小于等于k的情況下統(tǒng)計(jì)處落在左區(qū)間的數(shù)目left和右區(qū)間的數(shù)目right
如果left>m/2&&right>m/2,當(dāng)前方案可行,嘗試中位數(shù)更大的方案
如果left<m/2&&right<m/2,則不可能
如果left<m/2&&right>m/2,中點(diǎn)應(yīng)該向右移動(dòng)
如果left>m/2&&right<m/2,中點(diǎn)應(yīng)該向左移動(dòng)
注意考慮中點(diǎn)的覆蓋情況。
還有,可能調(diào)整到最后也沒(méi)法滿足條件,那么也輸出-1
具體看程序吧
 1 # include <cstdio>
 2 using namespace std;
 3 # include <algorithm>
 4 # include <cstring>
 5 int n,c,f;
 6 struct node
 7 {
 8    int s,c;
 9    int id;
10 }cows[100005],cowc[100005];
11 int rank[100005];
12 bool cmps(node a,node b)
13 {
14     return a.s<b.s;
15 }
16 bool cmpc(node a,node b)
17 {
18     return a.c<b.c;
19 }
20 int chk(int pos)
21 {
22     int left=0,right=0,tf=f;
23     bool mid=false;
24     for(int i=0;i<c;i++)
25       if(rank[cowc[i].id]<pos&&left<n/2)
26          if(tf>=cowc[i].c)
27             left++,tf-=cowc[i].c;
28          else break;
29       else if(rank[cowc[i].id]==pos&&!mid)
30          if(tf>=cowc[i].c)
31              mid=true,tf-=cowc[i].c;
32          else  break;
33       else if(rank[cowc[i].id]>pos&&right<n/2)
34          if(tf>=cowc[i].c)
35              right++,tf-=cowc[i].c;
36          else break;
37     if(left>=n/2&&right>=n/2&&mid) return 0;
38     else if(left>=n/2return 1;
39     else if(right>=n/2return -1;
40     else if(left<n/2&&right<n/2return -2;
41 }
42 int main()
43 {
44     scanf("%d%d%d",&n,&c,&f);
45     for(int i=0;i<c;i++)
46     {
47       scanf("%d%d",&cows[i].s,&cows[i].c);
48       cows[i].id=i;
49     }
50     memcpy(cowc,cows,sizeof(cows));
51     sort(cows,cows+c,cmps);
52     sort(cowc,cowc+c,cmpc);
53   /*  printf("sorted by s\n");
54        for(int i=0;i<c;i++)
55          printf("(%d,%d)\n",cows[i].id,cows[i].s);
56     printf("\n");
57     printf("sorted by c\n");
58        for(int i=0;i<c;i++)
59          printf("(%d,%d)\n",cowc[i].id,cowc[i].c);
60     printf("\n");*/
61     int s=n/2,e=c-1-n/2;
62     for(int i=0;i<c;i++)
63       rank[cows[i].id]=i;
64     while(s<=e)
65     {
66        int mid=(s+e)/2;
67        switch(chk(mid))
68        {
69           case -1:
70                s=mid+1;
71                break;
72           case 1:
73                e=mid-1;
74                break;
75           case 0:
76                s=mid+1;
77                break;
78           case -2:
79                printf("-1\n");
80                return 0;
81        };
82     }
83     if(chk(s-1)==0)
84       printf("%d\n",cows[s-1].s);
85     else
86       printf("-1\n");
87    //   system("pause");
88       return 0;
89 }
90 


posted on 2010-11-07 02:31 yzhw 閱讀(359) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): search

<2010年10月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

導(dǎo)航

統(tǒng)計(jì)

公告

統(tǒng)計(jì)系統(tǒng)

留言簿(1)

隨筆分類(lèi)(227)

文章分類(lèi)(2)

OJ

最新隨筆

搜索

積分與排名

最新評(píng)論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲日本一区二区| 一二三区精品福利视频| 在线看欧美日韩| 亚洲人成人一区二区三区| 美女黄毛**国产精品啪啪| 亚洲欧美日韩在线不卡| 中文精品一区二区三区| 亚洲手机视频| 久久大香伊蕉在人线观看热2| 西西裸体人体做爰大胆久久久| 午夜精品在线观看| 久久国产精品久久久久久电车| 久久久亚洲综合| 久久综合久久88| 欧美激情精品久久久久久黑人| 欧美极品一区二区三区| 欧美色精品在线视频| 欧美亚一区二区| 国产一区二区三区在线观看网站| 激情文学一区| 亚洲免费观看在线观看| 亚洲欧美日韩精品久久久久| 欧美一区二区三区在线| 免费在线观看日韩欧美| 日韩一级免费观看| 亚欧成人精品| 欧美电影免费观看高清| 国产精品伦理| 亚洲精品欧美日韩专区| 一区二区精品| 久久综合久色欧美综合狠狠 | 欧美午夜久久| 影音先锋一区| 亚洲女同性videos| 欧美大片在线观看一区二区| 一区二区三区色| 久久在线免费观看视频| 国产精品香蕉在线观看| 91久久精品日日躁夜夜躁国产| 一区二区三区日韩| 免费视频一区| 欧美在线观看网站| 国产精品国产三级国产普通话蜜臀| 国产一区二区按摩在线观看| 一本色道精品久久一区二区三区| 久久久综合激的五月天| 99精品久久免费看蜜臀剧情介绍| 久久久久免费观看| 国内成人在线| 欧美一区二区三区视频| 亚洲片在线资源| 毛片一区二区| 黄色日韩在线| 久久成人免费网| 一本色道久久加勒比精品| 欧美成人日本| 西西裸体人体做爰大胆久久久| 欧美国产日韩免费| 欧美一级二区| 国产精品视频内| 亚洲视频精品| 亚洲精品免费在线| 米奇777超碰欧美日韩亚洲| 国产日韩欧美电影在线观看| 中文一区二区在线观看| 亚洲欧洲一区| 久久亚洲二区| 亚洲国产成人av在线| 久久综合伊人77777蜜臀| 欧美一区二粉嫩精品国产一线天| 国产伦精品一区二区三区高清| 性欧美xxxx视频在线观看| 宅男噜噜噜66一区二区66| 欧美色图首页| 亚洲欧美日韩爽爽影院| 亚洲天堂偷拍| 国产一区久久| 亚洲第一精品福利| 欧美日韩国产影片| 亚洲欧美日韩国产一区二区| 亚洲婷婷综合久久一本伊一区| 国产精品福利在线| 久久www免费人成看片高清| 欧美一区二区三区视频| 精品91视频| 亚洲国产cao| 欧美视频一区二区在线观看| 先锋资源久久| 久久国产手机看片| 亚洲精品国产系列| 中文成人激情娱乐网| 国产午夜精品久久久| 男人插女人欧美| 欧美精品一区二区三区在线看午夜| 国产精品99久久久久久有的能看| 亚洲综合电影一区二区三区| 一区二区亚洲欧洲国产日韩| 亚洲欧洲久久| 国产亚洲精品高潮| 亚洲国产91色在线| 国产精品伊人日日| 欧美韩日高清| 国产精品永久免费在线| 免费日韩精品中文字幕视频在线| 欧美激情亚洲| 久久视频国产精品免费视频在线| 欧美成人一区二区三区在线观看| 亚洲综合视频网| 久久亚洲欧美国产精品乐播| 亚洲欧美国产77777| 免费观看成人| 久久久久9999亚洲精品| 欧美日韩精品是欧美日韩精品| 久久久久亚洲综合| 欧美日韩一区二区三区在线看| 久久视频这里只有精品| 欧美三级乱人伦电影| 亚洲电影免费| 国产精品伦一区| 亚洲视频免费在线| 亚洲另类在线视频| 国产综合色在线| 一区二区三区偷拍| 亚洲人成在线观看网站高清| 亚洲在线网站| 亚洲午夜一二三区视频| 欧美jizz19hd性欧美| 欧美wwwwww| 国精品一区二区三区| 一区二区三区精品视频| 亚洲精品麻豆| 麻豆视频一区二区| 欧美激情第五页| 伊人婷婷欧美激情| 欧美专区中文字幕| 欧美在线免费视屏| 国产精品综合视频| 宅男精品视频| 欧美亚洲在线| 国产欧美韩日| 午夜精品久久久久久久久久久| 亚洲午夜一区二区| 国产精品成人一区二区网站软件| 日韩视频中文字幕| 一区二区三区**美女毛片| 欧美日本国产视频| 一区二区三区高清不卡| 亚洲午夜伦理| 国产精品一区二区在线观看不卡| 亚洲欧美自拍偷拍| 久久亚洲欧美| 亚洲电影欧美电影有声小说| 久久综合免费视频影院| 亚洲国产高清在线观看视频| 亚洲精品免费观看| 欧美日韩中文字幕精品| 亚洲视频一二| 久久久久欧美精品| 亚洲国产成人久久综合| 欧美大片免费观看| 亚洲片在线观看| 亚洲欧美日韩成人| 在线不卡中文字幕| 欧美精品手机在线| 亚洲在线免费观看| 猛男gaygay欧美视频| 亚洲日本成人女熟在线观看| 欧美日韩成人免费| 欧美一区二区三区播放老司机 | 老牛嫩草一区二区三区日本| 一区在线观看| 欧美日韩视频一区二区| 午夜视频一区在线观看| 六月婷婷久久| 夜夜嗨av色一区二区不卡| 国产精品一区久久| 蜜桃av一区二区| 亚洲香蕉伊综合在人在线视看| 久久免费视频这里只有精品| 日韩亚洲欧美成人一区| 国语自产偷拍精品视频偷| 欧美猛交免费看| 久久国产精品一区二区三区四区| 亚洲清纯自拍| 免费久久99精品国产| 亚洲欧美三级伦理| 亚洲精品资源美女情侣酒店| 国产日韩在线看片| 免费h精品视频在线播放| 欧美一区二区视频网站| 国产日产高清欧美一区二区三区| 欧美在线观看一区| 亚洲免费观看| 欧美顶级少妇做爰| 久久久九九九九| 午夜精品免费在线| 一区二区三区 在线观看视频| 在线免费观看日本一区| 国产乱码精品一区二区三区不卡| 欧美日本三区|