码迷,mamicode.com
首页 > 其他好文 > 详细

未完成代码存档

时间:2017-04-23 01:07:36      阅读:151      评论:0      收藏:0      [点我收藏+]

标签:class   har   for   main   code   UI   blog   max   include   

#include <cstdio>
#define Max 100000

typedef long long LL;
struct node
{
    LL l,r,dis,flag,Min_value,Max_value,set,time_set,time_add;
}tr[Max<<2];
int max(LL a,LL b){return a>b?a:b;}
int min(LL a,LL b){return a>b?b:a;} 
LL n,m,Time;
void up(LL k)
{
    tr[k].dis=tr[k<<1].dis+tr[k<<1|1].dis;
    tr[k].Max_value=max(tr[k<<1].Max_value,tr[k<<1|1].Max_value);
    tr[k].Min_value=min(tr[k<<1].Min_value,tr[k<<1|1].Min_value);
}
void build(LL k,LL l,LL r)
{
    tr[k].l=l;tr[k].r=r;
    if(l==r)
    {
        scanf("%lld",&tr[k].dis);
        tr[k].Max_value=tr[k].dis;
        tr[k].Min_value=tr[k].dis;
        return;
    }
    LL mid=(tr[k].l+tr[k].r)>>1;
    build(k<<1,l,mid);
    build(k<<1|1,mid+1,r);
    up(k);
}
void section_add(int k,int l,int r,int v)
{
    if(tr[k].l==l&&tr[k].r==r)
    {
        tr[k].dis+=(r-l+1)*v;
        tr[k].flag+=v;
        tr[k].time_add=++Time;
        return;
    }
    int mid=(tr[k].l+tr[k].r )>>1;
    if(l>mid) section_add(k<<1|1,l,r,v);
    else if(r<=mid) section_add(k<<1,l,r,v);
    else section_add(k<<1,l,mid,v),section_add(k<<1|1,mid+1,r,v);
    up(k);
}
void section_set(int k,int l,int r,int v)
{
    if(tr[k].l==l&&tr[k].r==r)
    {
        tr[k].dis=(r-l)*v;
        tr[k].set=v;
        tr[k].time_set=++Time;
        return;
    }
    int mid=(tr[k].l+tr[k].r)>>1;
    if(l>mid) section_set(k<<1|1,l,r,v);
    else if(r<=mid) section_set(k<<1,l,r,v);
    else section_set(k<<1,l,mid,v),section_set(k<<1|1,mid+1,r,v);
    up(k);
}
void pushdown(LL k)
{
    if(tr[k].l==tr[k].r) return;
    if(tr[k].time_add<tr[k].time_set)
    {
        tr[k<<1].set=tr[k].set;
        tr[k<<1|1].set=tr[k].set;
        tr[k<<1].dis=tr[k].set*(tr[k<<1].r-tr[k<<1].l+1);
        tr[k<<1|1].dis=tr[k].set*(tr[k<<1|1].r-tr[k<<1|1].l+1);
        tr[k<<1].time_set=tr[k].time_set;
        tr[k<<1|1].time_set=tr[k].time_set;
        tr[k<<1].time_add=tr[k].time_add;
        tr[k<<1|1].time_add=tr[k].time_add;
        tr[k].set=0;
        tr[k].flag=0;
        tr[k].time_add=0;
        tr[k].time_set=0;
    }
    if(tr[k].time_set<tr[k].time_add)
    {
        tr[k<<1].set=tr[k].set;
        tr[k<<1|1].set=tr[k].set;
        tr[k<<1].dis=tr[k].set*(tr[k<<1].r-tr[k<<1].l+1);
        tr[k<<1|1].dis=tr[k].set*(tr[k<<1|1].r-tr[k<<1|1].l+1);
        tr[k<<1].time_set=tr[k].time_set;
        tr[k<<1|1].time_set=tr[k].time_set;
        tr[k<<1].time_add=tr[k].time_add;
        tr[k<<1|1].time_add=tr[k].time_add;
        tr[k<<1].dis+=tr[k].flag*(tr[k<<1].r-tr[k<<1].l+1);
        tr[k<<1|1].dis+=tr[k].flag*(tr[k<<1|1].r-tr[k<<1|1].l+1);
        tr[k].set=0;
        tr[k].flag=0;
        tr[k].time_add=0;
        tr[k].time_set=0;
    }
}
LL query(LL k,LL l,LL r)
{
    if(tr[k].l==l&&tr[k].r==r) return tr[k].dis;
    if(tr[k].flag||tr[k].set) pushdown(k);
    LL mid=(tr[k].l+tr[k].r)>>1;
    if(l>mid) return query(k<<1|1,l,r);
    else if(r<=mid) return query(k<<1,l,r);
    else return query(k<<1,l,mid)+query(k<<1|1,mid+1,r);
    up(k);
}
LL query_max(LL k,LL l,LL r)
{
    if(tr[k].l==l&&tr[k].r==r) return tr[k].Max_value;
    if(tr[k].flag||tr[k].set) pushdown(k);
    LL mid=(tr[k].l+tr[k].r)>>1;
    if(l>mid) return query_max(k<<1|1,l,r);
    else if(r<=mid) return  query_max(k<<1,l,r);
    else return max(query_max(k<<1,l,mid),query_max(k<<1|1,mid+1,r));
    up(k);
}
LL query_min(LL k,LL l,LL r)
{
    if(tr[k].l==l&&tr[k].r==r) return tr[k].Min_value;
    if(tr[k].flag||tr[k].set) pushdown(k);
    LL mid=(tr[k].l+tr[k].r)>>1;
    if(l>mid) return query_min(k<<1|1,l,r);
    else if(r<=mid) return  query_min(k<<1,l,r);
    else return min(query_min(k<<1,l,mid),query_min(k<<1|1,mid+1,r));
    up(k);
}
int main()
{
    scanf("%lld%lld",&n,&m);
    build(1,1,n);
    char str[4];
    for(int x,y,z;m--;)
    {
        scanf("%s",str+1);
        if(str[1]==a)
        {
            scanf("%lld%lld%lld",&x,&y,&z);
            section_add(1,x,y,z);
        }
        else if(str[1]==s)
        {
            if(str[2]==e)
            {
                scanf("%lld%lld%lld",&x,&y,&z);
                section_set(1,x,y,z);
            }
            else if(str[2]==u)
            {
                scanf("%lld%lld",&x,&y);
                printf("%lld\n",query(1,x,y));
            }
        }
        else if(str[1]==m)
        {
            scanf("%lld%lld",&x,&y);
            if(str[2]==a)
                printf("%lld\n",query_max(1,x,y));
            else if(str[2]==i)
                printf("%lld\n",query_min(1,x,y));
        }
    }
    return 0; 
}
/*
10 6
3 9 2 8 1 7 5 0 4 6
add 4 9 4
set 2 6 2
add 3 8 2
sum 2 10
max 1 7
min 3 6
*/

 

未完成代码存档

标签:class   har   for   main   code   UI   blog   max   include   

原文地址:http://www.cnblogs.com/ruojisun/p/6750051.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!