zoukankan      html  css  js  c++  java
  • 线段树模板

    1、前言

    线段树相较于树状数组、是一种较为复杂的数据结构。常用的操作有以下两种:
    1、单点修改O(logn)
    2、区间查询O(logn)

    2、模板

    常用的操作函数有以下几种


    struct Node
    {
        int l, r;
        int sum;
    }tr[N * 4];  //一般最大是 4 * N
    

    1、更新pushup

    void pushup(int u)
    {
        tr[u].sum = tr[u << 1].sum + tr[u << 1 | 1].sum;
    }
    

    2、建树build

    void build(int u, int l, int r)
    {
        if (l == r) tr[u] = {l, r, w[r]};
        else
        {
            tr[u] = {l, r};
            int mid = l + r >> 1;
            build(u << 1, l, mid), build(u << 1 | 1, mid + 1, r);
            pushup(u);
        }
    }
    

    3、查询query

    int query(int u, int l, int r)
    {
        if (tr[u].l >= l && tr[u].r <= r) return tr[u].sum;
        int mid = tr[u].l + tr[u].r >> 1;
        int sum = 0;
        if (l <= mid) sum = query(u << 1, l, r);
        if (r > mid) sum += query(u << 1 | 1, l, r);
        return sum;
    }
    

    4、修改modify

    void modify(int u, int x, int v)
    {
        if (tr[u].l == tr[u].r) tr[u].sum += v;
        else
        {
            int mid = tr[u].l + tr[u].r >> 1;
            if (x <= mid) modify(u << 1, x, v);
            else modify(u << 1 | 1, x, v);
            pushup(u);
        }
    }
    
  • 相关阅读:
    CF 234 C Weather(粗暴方法)
    给工作赋予的新意义——Leo鉴书78
    获取集合的方法
    VS 统计代码行数
    , ,
    指针的删除动作
    C++ 名称空间
    boost::token_compress_on
    指针与引用
    容器的end()方法
  • 原文地址:https://www.cnblogs.com/xiaofrank/p/14463739.html
Copyright © 2011-2022 走看看