zoukankan      html  css  js  c++  java
  • hdu 1698 Just a Hook 基本线段树

    使用线段树更新每段区间的奖(1,2,3),最后在统计整段区间的数和,基本线段树,果断1A啊

    #include<iostream>
    #include<stdio.h>
    using namespace std;
    #define N 100000
    struct node{
        int l,r,p;
    }a[N*4];
    int n;
    void build(int left,int right,int i){
        a[i].l=left;
        a[i].r=right;
        a[i].p=1;
        if(a[i].l==a[i].r){
            return ;
        }
        int mid=(a[i].l+a[i].r)>>1;
        build(left,mid,i*2);
        build(mid+1,right,i*2+1);
    //    a[i].p=a[i*2].p+a[i*2+1].p;
    }
    void updata(int left,int right,int i,int p){
        if(left==a[i].l&&a[i].r==right){
            a[i].p=p;
            return ;
        }
        if(a[i].p>=1){
            a[i*2].p=a[i].p;
            a[i*2+1].p=a[i].p;
            a[i].p=-1;
        }
        int mid=(a[i].l+a[i].r)>>1;
        if(mid>=right)
            updata(left,right,i*2,p);
        else if(mid<left)
            updata(left,right,i*2+1,p);
        else{
            updata(left,mid,i*2,p);
            updata(mid+1,right,i*2+1,p);
        }
     //   a[i].p=a[i*2].p+a[i*2+1].p;
    }
    int ans=0;
    void sum(int i){
     //   cout<<a[i].l<<" "<<a[i].r<<" "<<a[i].p<<endl;
        if(a[i].p!=-1){
            ans+=a[i].p*(a[i].r-a[i].l+1);
            return ;
        }
        sum(i*2);
        sum(i*2+1);
    
    }
    int main(){
        int t,s,x,y,z;
        scanf("%d",&t);
        int cou=1;
        while(t--){
            scanf("%d %d",&n,&s);
            build(1,n,1);
            while(s--){
                scanf("%d%d%d",&x,&y,&z);
                updata(x,y,1,z);
            }
            ans=0;
            sum(1);
            printf("Case %d: The total value of the hook is %d.
    ",cou++,ans);
        }
    }
    

  • 相关阅读:
    python redis操作
    subprocess模块的使用
    tcpcopy 流量复制工具
    Python名称空间与闭包
    python 偏函数
    Python面向对象的特点
    vsftpd 安装及使用虚拟用户配置
    shell 并发脚本
    Centos7 搭建LVS DR模式 + Keepalive + NFS
    python pip 升级
  • 原文地址:https://www.cnblogs.com/wzzkaifa/p/6979158.html
Copyright © 2011-2022 走看看