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

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

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

2019-11-14 08:44:07
字體:
來源:轉載
供稿:網友

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
久久久久久久国产精品视频| 日韩欧美在线观看视频| 日韩激情av在线免费观看| 久久亚洲国产精品| 国产成人+综合亚洲+天堂| 亚洲成av人影院在线观看| 久久中文字幕在线| 欧洲亚洲免费视频| 中日韩美女免费视频网站在线观看| 欧美插天视频在线播放| 国产精品稀缺呦系列在线| 久久亚洲成人精品| 日韩精品视频在线观看网址| 国产亚洲xxx| 国产欧美日韩中文字幕| 久久免费精品日本久久中文字幕| 国产在线观看91精品一区| 亚洲国产精品悠悠久久琪琪| 日韩欧美国产成人| 日本在线观看天堂男亚洲| 欧美激情亚洲一区| 国产一区二区三区视频在线观看| 97国产精品人人爽人人做| 视频一区视频二区国产精品| 91免费国产视频| 欧美尤物巨大精品爽| 中日韩午夜理伦电影免费| 欧美在线观看一区二区三区| 97久久久久久| 亚洲精品国产精品乱码不99按摩| 色综合天天综合网国产成人网| www.欧美免费| 日本sm极度另类视频| 亚洲欧洲国产伦综合| 国产精品成人国产乱一区| 成人精品视频久久久久| www国产亚洲精品久久网站| 久久影院资源站| 亚洲免费小视频| xx视频.9999.com| 韩国一区二区电影| 欧美主播福利视频| 亚洲电影免费观看高清完整版| 国产精品无码专区在线观看| 一道本无吗dⅴd在线播放一区| 日韩免费观看在线观看| 大荫蒂欧美视频另类xxxx| 欧美一级大片视频| 欧美日韩另类视频| 欧美成人手机在线| 亚洲视频国产视频| 欧美精品国产精品日韩精品| 欧美在线欧美在线| 亚洲视频在线播放| 国产美女精彩久久| 久久影视电视剧免费网站清宫辞电视| 97精品一区二区视频在线观看| 国产欧美日韩亚洲精品| y97精品国产97久久久久久| 97久久久久久| 欧美一区二区三区免费观看| 91成人在线播放| 欧美床上激情在线观看| 日韩免费视频在线观看| 精品久久久久久电影| 亚洲第一精品夜夜躁人人爽| 亚洲成人精品久久| 久久亚洲私人国产精品va| 国产精品免费久久久久久| 亚洲最新av网址| 91在线精品视频| 亚洲欧洲日产国产网站| 91免费的视频在线播放| 亚洲天堂av综合网| 97在线视频免费观看| 国产黑人绿帽在线第一区| 日韩精品免费在线| 色偷偷av亚洲男人的天堂| 日韩av网站在线| 国产成人涩涩涩视频在线观看| 国内精品视频在线| 最近中文字幕mv在线一区二区三区四区| 少妇高潮久久77777| 久久中文字幕一区| 国产69精品久久久久99| 欧美剧在线观看| 国产精品福利网站| 亚洲国产精品成人精品| 92裸体在线视频网站| 中文字幕久热精品在线视频| 亚洲电影天堂av| 亚洲欧美第一页| 国产91露脸中文字幕在线| 一区二区在线视频| 国产精品女人久久久久久| 久久夜色精品亚洲噜噜国产mv| 欧美噜噜久久久xxx| 欧美精品少妇videofree| 国产精品免费在线免费| 国产成人久久久| 精品中文字幕在线2019| 国产精品视频自拍| 亚洲伊人久久综合| 亚洲一区二区久久久久久| 国产精品免费久久久久久| 91久久精品国产91久久性色| 久久99久久99精品中文字幕| 亚洲aa中文字幕| 欧美日韩亚洲系列| 日本精品一区二区三区在线播放视频| 精品激情国产视频| 九色91av视频| 精品国产乱码久久久久酒店| 国产成人在线一区| 亚洲欧美综合精品久久成人| 日韩女优在线播放| 性欧美长视频免费观看不卡| 亚洲在线第一页| 国产精品久久久久久久午夜| 超薄丝袜一区二区| 51午夜精品视频| 国产精品欧美久久久| 国产午夜精品麻豆| 97久久国产精品| 亚洲人成欧美中文字幕| 亚洲天堂免费在线| 日韩亚洲精品视频| 色噜噜亚洲精品中文字幕| 91精品国产成人| 91精品国产综合久久久久久久久| 国产欧美日韩高清| 久久99青青精品免费观看| 成人网欧美在线视频| 久久久久久久久久av| 欧美一级电影久久| 午夜精品一区二区三区视频免费看| 欧美人在线视频| 日韩在线视频导航| 国内精品一区二区三区四区| 亚洲欧洲日产国码av系列天堂| 久久久久国产精品免费| 最近2019年好看中文字幕视频| 欧美国产日产韩国视频| 国产亚洲福利一区| 高跟丝袜欧美一区| 久久高清视频免费| 国产精品视频精品| 91免费视频国产| 欧美美女15p| 热久久免费视频精品| 成人深夜直播免费观看| 91精品久久久久久久久久久久久久| 中文字幕久久久av一区| 亚洲精品久久久久久久久久久久久| 亚洲伊人一本大道中文字幕| 米奇精品一区二区三区在线观看| 国产日韩av在线播放| 欧美日韩国产一中文字不卡| 日韩欧美亚洲成人| 亚洲欧美精品伊人久久| 亚洲黄色www| 亚洲韩国青草视频| 国产一区二区视频在线观看| 成人免费网站在线观看|