最大值最小化

贪心+二分入门题:

 

#include <iostream>
#include<string.h>
#include<algorithm>
#include<cstdio>
#define CLR(arr,val) memset(arr,val,sizeof(arr))
using namespace std;
void in(int &a)
{
    char ch;
    while((ch=getchar())<'0'||ch>'9');
    for( a=0;ch>='0'&&ch<='9';ch=getchar()) a=a*10+ch-'0';

}
/*int d,x,y;
void extend_gcd(int a,int b,int& d,int& x,int& y)
{
    if(b==0)
    {
        d=a;
        x=1;
        y=0;
        return;
    }
   extend_gcd(b,a%b,d,x,y);
    int t=x-(a/b)*y;
        x=y;
        y=t;
}
int main()
{
    int a,b;
    while(cin>>a>>b)
    {
       extend_gcd(a,b,d,x,y);
       while(x<0) x+=b;
       cout<<x<<endl;
    }
    return 0;
}
*/
#define N 10005
int p[N],n,m,maxx,sum;
void input()
{
    maxx=-1,sum=0;
    for(int i=0;i<n;++i)
    {
        cin>>p[i];
        if(maxx<p[i]) maxx=p[i];
        sum+=p[i];
    }
}
bool _test(int  t)
{
    bool flag=true;
    int s=0,num=0;
    for(int i=0;i<n;++i)
    {
        if(p[i]>t)
        {
            flag=false;
            break;
        }
        if(s+p[i]>t)
        {
            s=p[i];
            num++;
            if(num>m-1)
            {
                flag=false;
                break;
            }

        }
        else
        {
            s+=p[i];
        }
    }
    return flag;
}
int bin_search()
{
    int l=maxx,r=sum;
    while(l<=r)
    {
        int mid=(l+r)>>1;
        if(_test(mid)) r=mid-1;
        else           l=mid+1;
    }
    return l;
}
int main()
{
    int T;
    cin>>T;
    while(T--)
    {
    cin>>n>>m;
    input();
    cout<<bin_search()<<endl;
    }
    return 0;
}


 

 

posted @ 2013-06-05 22:08  jlins  阅读(164)  评论(0编辑  收藏  举报