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

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

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

2019-11-11 07:19:58
字體:
來源:轉載
供稿:網友

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精品久久久久久| 日本不卡视频在线播放| 久久久91精品国产| 国产精品一区二区久久久久| 欧美在线视频播放| 欧美精品精品精品精品免费| 欧美精品福利视频| 欧美日韩国产精品一区二区三区四区| 成人激情视频免费在线| 欧美中文字幕精品| 亚洲图片制服诱惑| 欧美亚洲伦理www| 国产精品欧美在线| 91人人爽人人爽人人精88v| 91精品在线观看视频| 欧美日韩亚洲精品一区二区三区| 亚洲精品美女久久久| 亚洲色图激情小说| 北条麻妃久久精品| 亚洲三级黄色在线观看| 久久久久久成人精品| 自拍偷拍亚洲在线| 日韩欧美在线看| 日韩视频免费在线观看| 国产精品天天狠天天看| 中文欧美在线视频| 操日韩av在线电影| 久久国产精彩视频| 国产91在线播放九色快色| 日韩精品中文字幕在线观看| 国产精品福利在线观看网址| 欧美日韩一区二区免费视频| 亚洲最新av网址| 欧美日韩亚洲一区二区三区| 日韩精品中文在线观看| 国产精品女视频| 少妇高潮久久久久久潘金莲| 国产成人一区二区在线| 尤物yw午夜国产精品视频| 欧美一性一乱一交一视频| 国产精品久久久久久久久久久久久| 国产精品久久久久久超碰| 国产精品国产自产拍高清av水多| 国产网站欧美日韩免费精品在线观看| 日本久久久久久久| 亚洲欧美国产日韩中文字幕| 欧美亚洲另类激情另类| 亚洲毛片在线观看.| 国产精品一区二区三区毛片淫片| 亚洲精品aⅴ中文字幕乱码| 久久亚洲精品成人| 欧美日韩国产激情| 九九热r在线视频精品| 亚洲乱码国产乱码精品精天堂| 日韩天堂在线视频| 亚洲国产成人精品久久久国产成人一区| 亚洲国产精品女人久久久| 中文字幕亚洲欧美日韩高清| 国产精品久久久久久久久久新婚| 亚洲精品国偷自产在线99热| 深夜福利91大全| 97香蕉超级碰碰久久免费软件| 亚洲丝袜在线视频| 久久久久久69| 91国在线精品国内播放| 一区二区三区 在线观看视| 欧美日韩国产中文精品字幕自在自线| 精品国产美女在线| 亚洲国产欧美一区二区三区同亚洲| 欧美极品xxxx| 精品亚洲一区二区三区四区五区| 亚洲深夜福利在线| 欧美国产日韩中文字幕在线| 中文字幕精品一区二区精品| 欧美风情在线观看| 亚洲精品自拍第一页| 亚洲一区二区久久| 欧美电影在线免费观看网站| 国产精品亚洲美女av网站| 精品高清美女精品国产区| 97色在线视频观看| 97视频免费在线看| 97免费在线视频| 欧美一区二区三区免费视| 日韩精品免费视频| 亚洲欧美一区二区三区在线| 欧美日韩美女在线观看| 欧美大片免费观看在线观看网站推荐| 欧美成人精品影院| 日本一本a高清免费不卡| 国产精品久久久久久久9999| 久久久久久久久久久av| 日韩中文字幕网站| 69影院欧美专区视频| 欧美日韩亚洲激情| 精品国产鲁一鲁一区二区张丽| 欧美尤物巨大精品爽| 国语自产精品视频在线看抢先版图片| 日韩av电影手机在线观看| 亚洲国产成人爱av在线播放| 国产日韩欧美视频在线| 一区二区三区高清国产| 国产在线精品播放| 日韩**中文字幕毛片| 一本色道久久综合狠狠躁篇的优点| 精品国产91久久久| 欧美激情视频在线免费观看 欧美视频免费一| 成人久久久久久久| 久久久久成人精品| 日本精品久久久久影院| 黄网动漫久久久| 中文在线资源观看视频网站免费不卡| 欧美在线视频免费播放| 激情亚洲一区二区三区四区| 亚洲国产精品美女| 国产精品自拍视频| 国产精品自产拍在线观看中文| 久久久电影免费观看完整版| 好吊成人免视频| 欧美精品激情在线| 97av在线视频免费播放| 亚洲免费视频在线观看| 在线观看亚洲视频| 亚洲精品资源在线| 96精品久久久久中文字幕| 日韩黄色在线免费观看| 日韩在线观看网站| 亚洲欧美日韩在线一区| 日本一欧美一欧美一亚洲视频| 欧美激情视频一区| 欧美一级大片在线观看| 日韩精品在线观看一区二区| 欧美国产日韩在线| 欧美国产日本高清在线| 高清欧美一区二区三区| 中文字幕亚洲一区二区三区五十路| 91免费精品国偷自产在线| 亚洲精品永久免费| 91高清视频免费观看| 国产精品男人爽免费视频1| 欧美做爰性生交视频| 国产精品1234| 国产午夜精品麻豆| 久久精品国产v日韩v亚洲| 欧美精品一区三区| 亚洲欧美另类在线观看| 国产精品视频网站| 国产日韩中文字幕在线| 国产精品日韩精品| 欧美激情一级二级| 色婷婷综合成人av| 日韩在线视频免费观看高清中文| 91久久精品久久国产性色也91| 亚洲午夜激情免费视频| 精品夜色国产国偷在线| 亚洲全黄一级网站| 成人免费在线视频网址| 精品动漫一区二区| 欧美日本国产在线| 亚洲精品99久久久久| 久久综合电影一区| 欧美成人免费小视频| 亚洲国产91色在线|