zoukankan      html  css  js  c++  java
  • [CF339D] Xenia and Bit Operation

    [CF339D] Xenia and Bit Operation - 线段树

    Description

    给定一个序列,每次选择一个点修改权值,然后求出全序列的值(每相邻两个元素按位或得到长度减半的序列,在对每相邻两个元素按位异或得到长度再次减半的序列……更替的进行按位或/异或)

    Solution

    不用想太多,直接线段树维护即可

    #include <bits/stdc++.h>
    using namespace std;
    
    #define int long long
    
    struct SegmentTree
    {
        struct Node
        {
            int val;
            int flag;
    
            Node operator+(const Node &rhs)
            {
                if (flag)
                    return {val ^ rhs.val, 0};
                else
                    return {val | rhs.val, 1};
            }
        };
    
        vector<Node> nodes;
    
        int n;
    
        SegmentTree(int n) : n(n)
        {
            nodes.resize(4 * n + 4);
        }
    
        void pushup(int p)
        {
            nodes[p] = nodes[p * 2] + nodes[p * 2 + 1];
        }
    
        void build(int p, int l, int r, const vector<int> &src)
        {
            if (l == r)
            {
                nodes[p] = {src[l], 0};
            }
            else
            {
                build(p * 2, l, (l + r) / 2, src);
                build(p * 2 + 1, (l + r) / 2 + 1, r, src);
                pushup(p);
            }
        }
    
        void modify(int p, int l, int r, int pos, int val)
        {
            if (l == r)
            {
                nodes[p] = {val, 0};
            }
            else
            {
                if (pos <= (l + r) / 2)
                    modify(p * 2, l, (l + r) / 2, pos, val);
                else
                    modify(p * 2 + 1, (l + r) / 2 + 1, r, pos, val);
                pushup(p);
            }
        }
    
        void Build(const vector<int> &src)
        {
            build(1, 1, n, src);
        }
    
        void Modify(int pos, int key)
        {
            modify(1, 1, n, pos, key);
        }
    
        int Query()
        {
            return nodes[1].val;
        }
    };
    
    signed main()
    {
        ios::sync_with_stdio(false);
    
        int n, m;
        cin >> n >> m;
        n = 1 << n;
    
        vector<int> a(n + 2);
        for (int i = 1; i <= n; i++)
            cin >> a[i];
    
        SegmentTree seg(n);
        seg.Build(a);
    
        for (int i = 1; i <= m; i++)
        {
            int x, y;
            cin >> x >> y;
            seg.Modify(x, y);
            cout << seg.Query() << endl;
        }
    }
    
    
  • 相关阅读:
    内核知识第六讲,内核编写规范,以及获取GDT表
    VS2015配置内核WDK7600环境,32位下.
    FTP服务器中vsftpd主配置文件解析
    DHCP配置部分
    Tomcat(.jsp)
    版本控制工具(上)——Git的基本使用
    【Hutool】Hutool工具类之随机工具——RandomUtil
    IDEA阿里Java规范插件的安装
    【Hutool】Hutool工具类之Http工具——HttpUtil
    sublime_text3常用操作与快捷键
  • 原文地址:https://www.cnblogs.com/mollnn/p/14424113.html
Copyright © 2011-2022 走看看