亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Codeforces 672D Robin Hood【思維+二分】這題思路有點勁啊

2019-11-14 09:03:47
字體:
來源:轉載
供稿:網友

D. Robin Hoodtime limit per test1 secondmemory limit per test256 megabytesinputstandard inputoutputstandard output

We all know the imPRessive story of Robin Hood. Robin Hood uses his archery skills and his wits to steal the money from rich, and return it to the poor.

There are n citizens in Kekoland, each person hasci coins. Each day, Robin Hood will take exactly1 coin from the richest person in the city and he will give it to the poorest person (poorest person right after taking richest's1 coin). In case the choice is not unique, he will select one among them at random. Sadly, Robin Hood is old and want to retire ink days. He decided to spend these last days with helping poor people.

After taking his money are taken by Robin Hood richest person may become poorest person as well, and it might even happen that Robin Hood will give his money back. For example if all people have same number of coins, then next day they will have same number of coins too.

Your task is to find the difference between richest and poorest persons wealth afterk days. Note that the choosing at random among richest and poorest doesn't affect the answer.

Input

The first line of the input contains two integers n andk (1?≤?n?≤?500?000,?0?≤?k?≤?109) — the number of citizens in Kekoland and the number of days left till Robin Hood's retirement.

The second line contains n integers, thei-th of them is ci (1?≤?ci?≤?109) — initial wealth of the i-th person.

Output

Print a single line containing the difference between richest and poorest peoples wealth.

ExamplesInput
4 11 1 4 2Output
2Input
3 12 2 2Output
0Note

Lets look at how wealth changes through day in the first sample.

[1,?1,?4,?2] [2,?1,?3,?2] or [1,?2,?3,?2]

So the answer is 3?-?1?=?2

In second sample wealth will remain the same for each person.

題目大意:

給你N個人的財富值,每天最有錢的人會給最沒錢的人一塊錢,問K天之后,最窮的人和最富有的人之間差多少錢。

思路:

1、virtual contest過程中一直在二分差值,然后發現最小值和最大值的問題不是很好處理,一直在想一個科學的連續二分的方式去枚舉出最小值和最大值。以一種二分套二分的方式去解,以失敗告終。

2、正解是這樣的:①因為時間越長(天數經過的越多),最大值就會越小,同理,最小值就會越大(所以這就是智障的去二分差值的理由?尼瑪本質是最大值最小值的變化好嘛,為毛要想到差值上去.......)那么我們二分一個最小值,接下來二分一個最大值。

②判定二分的過程很簡單,對于枚舉最小值的時候,如果需要的最少天數小于等于k,那么就加大最小值,否則減小最小值即可。那么二分枚舉最大值的時候同理即可。

③問題的坑點在于維護上下界。對于總值:sum,如果sum%n==0,那么最小值的上界就是sum/n,最大值的下界也是sum/n.當sum%n!=0的時候,最小值的上界還是sum/n,但是最大值的下界應該是sum/n+1.這里被坑了......................

3、過程維護最終解,細心一些沒有別的了。

Ac代碼:

#include<stdio.h>#include<string.h>#include<algorithm>using namespace std;#define ll __int64ll a[500500];ll n,m;int Slove(ll mid){    ll sum=0;    for(int i=1;i<=n;i++)    {        if(a[i]<mid)sum+=mid-a[i];    }    if(sum<=m)return 1;    else return 0;}int Slove2(ll mid){    ll sum=0;    for(int i=n;i>=1;i--)    {        if(a[i]>mid)sum+=abs(mid-a[i]);    }    if(sum<=m)return 1;    else return 0;}int main(){    while(~scanf("%I64d%I64d",&n,&m))    {        ll sum=0;        ll up,down;        for(int i=1;i<=n;i++)        {            scanf("%I64d",&a[i]);            sum+=a[i];        }        if(sum%n==0)up=down=sum/n;        else up=sum/n,down=up+1;        sort(a+1,a+1+n);        ll l=0;        ll r=up;        ll minn=-1;        while(r-l>=0)        {            ll mid=(l+r)/2;            if(Slove(mid)==1)            {                minn=mid;                l=mid+1;            }            else r=mid-1;        }        l=down;        r=1000000000;        ll maxn=-1;        while(r-l>=0)        {            ll mid=(l+r)/2;            if(Slove2(mid)==1)            {                maxn=mid;                r=mid-1;            }            else l=mid+1;        }        printf("%I64d/n",maxn-minn);    }}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲国产成人久久综合一区| 国产91精品久| 亚洲а∨天堂久久精品9966| 97视频在线观看播放| 韩国国内大量揄拍精品视频| 久久这里只有精品视频首页| 欧美巨乳在线观看| 国产第一区电影| 欧美日韩成人黄色| 欧美精品在线播放| 国产精品第一页在线| 黑人巨大精品欧美一区二区一视频| 91国产美女在线观看| 日韩中文字幕久久| 成人精品福利视频| 伦理中文字幕亚洲| 日韩在线一区二区三区免费视频| 亚洲黄色在线看| 亚洲成人久久一区| 国产日韩欧美中文| 亚洲国产成人在线播放| 国产色视频一区| 国语对白做受69| 国产丝袜视频一区| 中文字幕欧美日韩va免费视频| 国产精品视频精品| 欧美激情videos| 国产精品爽黄69天堂a| 久久精品99久久香蕉国产色戒| 日本精品视频网站| 国产欧美日韩中文字幕在线| 亚洲精品自拍视频| 亚洲精品中文字幕av| 在线视频日韩精品| 成人免费直播live| 久久不射热爱视频精品| 欧美美女18p| 国产999视频| 亚洲人在线观看| 国产视频精品xxxx| 欧美成aaa人片免费看| 欧美在线激情视频| 亚洲女人天堂视频| 国内精品久久久久久影视8| 欧美性理论片在线观看片免费| 日韩精品视频观看| 久久香蕉国产线看观看网| 久久国内精品一国内精品| 91免费精品视频| 91欧美精品成人综合在线观看| 欧美在线一区二区三区四| 久久亚洲一区二区三区四区五区高| 国产精品一区久久| 97久久精品在线| 欧美精品手机在线| 国产美女被下药99| 亚洲精品国产综合区久久久久久久| 欧美老肥婆性猛交视频| 在线精品91av| 亚洲第一区中文99精品| 欧美日韩一区二区三区在线免费观看| 国产一区二区三区直播精品电影| 亚洲色图偷窥自拍| 亚洲一区亚洲二区亚洲三区| 日韩欧美在线观看视频| 美女啪啪无遮挡免费久久网站| 亚洲电影免费观看高清| 国产成人福利视频| 日韩中文字幕在线免费观看| 日韩欧美综合在线视频| 久久久久中文字幕| 国产精品美女www爽爽爽视频| 亚洲精品国产精品乱码不99按摩| 国产91ⅴ在线精品免费观看| 成人自拍性视频| 国产一区二区三区在线播放免费观看| 久久久爽爽爽美女图片| 亚洲欧美日韩国产精品| 精品国产一区二区三区在线观看| 午夜剧场成人观在线视频免费观看| 不卡伊人av在线播放| 国产视频一区在线| 亚洲精品自拍第一页| 激情成人中文字幕| 91高潮在线观看| 国产在线不卡精品| 中文字幕亚洲欧美在线| 欧美高清自拍一区| 亚洲级视频在线观看免费1级| 超碰91人人草人人干| 国产精品自产拍在线观| 国产成人亚洲综合91精品| 国产一区二区三区高清在线观看| 国内精品久久久久久| 亚洲国产精品久久久| 日韩美女激情视频| 国产精品成久久久久三级| 久久久97精品| 欧美成aaa人片免费看| www国产亚洲精品久久网站| 亚洲精品狠狠操| 午夜精品一区二区三区在线视频| 久久99精品久久久久久噜噜| 国产精品欧美久久久| 欧美一级淫片播放口| 一本色道久久综合狠狠躁篇怎么玩| 欧美国产精品日韩| 久久这里只有精品视频首页| 国内免费精品永久在线视频| 国产伦精品免费视频| 97**国产露脸精品国产| 欧美性生交xxxxx久久久| 国产女同一区二区| 992tv成人免费影院| 欧美精品中文字幕一区| 国产精品久久久久久久久久99| 久久久久久久久久国产精品| 亚洲福利在线视频| 国产精品av电影| 97精品国产97久久久久久免费| 亚洲国产三级网| 欧美一级黄色网| 疯狂做受xxxx欧美肥白少妇| 美女扒开尿口让男人操亚洲视频网站| 国产亚洲一区二区精品| 精品女同一区二区三区在线播放| 精品国产乱码久久久久久婷婷| 亚洲精品美女在线| 久久久久久av| 亚洲理论在线a中文字幕| 日韩福利视频在线观看| 俺去啦;欧美日韩| 日韩电影中文 亚洲精品乱码| 日韩三级影视基地| 亚洲最新中文字幕| 国产精品成人免费电影| 成人日韩av在线| 国产成人鲁鲁免费视频a| 91视频免费在线| 91精品综合久久久久久五月天| 亚洲天堂男人的天堂| 欧美精品性视频| 久久99热这里只有精品国产| 97超碰色婷婷| 久久久精品999| 久久久国产一区二区三区| 日韩成人在线网站| 在线午夜精品自拍| 亚洲欧美日本伦理| 91青草视频久久| 日韩av电影在线免费播放| 2018中文字幕一区二区三区| 97超碰蝌蚪网人人做人人爽| 中文字幕久久亚洲| 性欧美激情精品| 亚洲成人久久久| 欧美在线播放视频| 国产亚洲精品91在线| 色在人av网站天堂精品| 免费av在线一区| 九九视频这里只有精品| 亚洲精品99久久久久中文字幕| 欧美插天视频在线播放| 国产精品第一区|