首页 > 其他分享 >ARC151D Binary Representations and Queries

ARC151D Binary Representations and Queries

时间:2024-01-14 12:11:37浏览次数:45  
标签:Binary Queries 集合 操作 ARC151D gets neq

ARC151D Binary Representations and Queries

题目链接:ARC151D Binary Representations and Queries

非常好思维题。

思路

首先我们会发现每个操作都是 \(\frac{n}{2}\) 的 \(A_i\),给另外 \(\frac{n}{2}\) 的 \(A_j\) 的增加。

这题直接去维护每个操作时间复杂度会开心的笑。

所以我们换个思路,先去探究一下这题的性质。

考虑一下,是否操作直接可以交换顺序?

反正我觉得不可以

现在我们来证明一下,交换操作不会对答案造成影响(这里交换的前提是要求 \(x_i\neq x_j\))。

设有操作 \(i,j\),且 \(x_i\neq x_j,i<j\)。

那么我们可以将 \(2^n\) 个下标分为 \(4\) 个集合。

1.\(b_{x_i}=y_i\) 且 \(b_{x_j}=y_j\)。

2.\(b_{x_i}=y_i\) 且 \(b_{x_j}\neq y_i\)。

3.\(b_{x_i}\neq y_i\) 且 \(b_{x_j}=y_j\)。

4.\(b_{x_i} \neq y_i\) 且 \(b_{x_j}\neq y_j\)。

这里的 \(b_i\) 表示第 \(i\) 位二进制的数。

我们将集合 \(u\) 向 \(v\) 连有向边,表示集合 \(u\) 内的下标会给 \(v\) 内的下标做贡献,边的权值为这次操作的编号。

注意这里的权值仅表示操作的编号。

  • 如果先做操作 \(i\),每个集合最终所得到的值如下:

    ​ \(2\gets 1\)。

    ​ \(3 \gets 1\)。

    ​ \(4 \gets 2+3+1\)。

  • 如果先做操作 \(j\),每个集合最终所得到的值如下:

    ​ \(2\gets 1\)。

    ​ \(3 \gets 1\)。

    ​ \(4 \gets 3+2+1\)。

不难发现,每个集合所得到的值并没有发生变化。

也就是说,只要满足 \(x_i\neq x_j\),我们是可以交换操作的。

有了这个性质,我们考虑把所有 \(x_i\) 相等的操作交换到一起操作。

这样就被分成了两个集合,这两个集合间互相给对方做贡献,方便我们快速统计每个集合收到贡献的系数。

这样就可以快速求 \(A_i\) 了。

时间复杂的 \(O(n\log n)\)。

CODE

#include<bits/stdc++.h>
using namespace std;

#define ll long long
#define mod 998244353

const int maxn=3e5+5;

int n,q;

ll a[maxn],tmp[maxn];

vector<int>tag[20];

int main()
{
    scanf("%d%d",&n,&q);
    for(int i=0;i<(1<<n);i++) scanf("%lld",&a[i]);
    for(int i=1;i<=q;i++)
    {
        int x,y;
        scanf("%d%d",&x,&y);
        tag[x].push_back(y);
    }
    for(int i=0;i<n;i++)
    {
        int x_1=1,y_1=0,x_0=1,y_0=0;//x是自己对自己的贡献系数,y是对方对自己的贡献系数
        for(int k:tag[i])
        {
            if(k) x_0=(x_0+y_1)%mod,y_0=(y_0+x_1)%mod;
            else x_1=(x_1+y_0)%mod,y_1=(y_1+x_0)%mod;
        }
        for(int j=0;j<(1<<n);j++)
        {
            if((j>>i)&1) tmp[j]=(x_1*a[j]%mod+y_1*a[j^(1<<i)]%mod)%mod;
            else tmp[j]=(x_0*a[j]%mod+y_0*a[j^(1<<i)]%mod)%mod;
        }
        for(int j=0;j<(1<<n);j++) a[j]=tmp[j];
    }
    for(int j=0;j<(1<<n);j++) printf("%lld ",a[j]);
}

标签:Binary,Queries,集合,操作,ARC151D,gets,neq
From: https://www.cnblogs.com/binbinbjl/p/17963521

相关文章

  • CF817F MEX Queries
    题意一个集合,初始为空。请你维护以下\(3\)种操作。把\([l,r]\)中在集合中没有出现过的数添加到集合中。把\([l,r]\)中在集合中出现过的数从集合中删掉。把\([l,r]\)中在集合中没有出现过的数添加到集合中,并把\([l,r]\)中在集合中出现过的数从集合中删掉。每......
  • CF1254D Tree Queries
    TreeQueriesLuoguCF1254D题面翻译给定一棵\(N\)个节点的树,有\(Q\)次操作。\(1\v\d\)给定一个点\(v\)和一个权值\(d\),等概率地选择一个点\(r\),对每一个点\(u\),若\(v\)在\(u\)到\(r\)的路径上,则\(u\)的权值加上\(d\)(权值一开始为\(0\))。\(2\v\)查......
  • --{module_name}_binary_host_mirror和--{module_name}_binary_site
    --{module_name}_binary_host_mirror和--{module_name}_binary_sitedemo//.npmrc文件sass_binary_site=https://npmmirror.com/mirrors/node-sass/nodejieba_binary_host_mirror=https://npm.taobao.org/mirrors/nodejiebagypgyp全称GenerateYourProjects(构建你的项目)n......
  • Maximum And Queries (hard version)
    题目传送门感觉这题比\(\rmF\)难啊,\(\rmF\)就是个板子,但为啥这题是蓝的,\(\rmF\)是紫的。思路首先考虑\(nq\)怎么做。发现很简单,按位贪心就行了。具体地说,从大到小枚举二进制位,判断答案中能否出现这一位,若\(i\)当前这一位没有值,那么必须被补全到这个值,否则无所谓,然......
  • AtCoder Regular Contest 168 F Up-Down Queries
    洛谷传送门AtCoder传送门貌似是第三道问号题?感觉前面这个转化不是人能想到的。。。考虑维护\(y\)的差分序列。更进一步地,我们类比slopetrick,维护一个可重集,里面有\(y_{i+1}-y_i\)个\(i\)(为了方便我们让每次操作时\(y_{m+1}\)加\(1\))。那么一次操作就相当于,插......
  • 无涯教程-PostgreSQL - SubQueries(子查询)
    子查询或内部查询或嵌套查询是另一个PostgreSQL查询中的查询,并嵌入在WHERE子句中。子查询可与SELECT,INSERT,UPDATE和DELETE语句以及=,<,>,>=,<=,IN等运算符一起使用。SELECT子查询子查询最常与SELECT语句一起使用。基本语法如下-SELECTcolumn_name[,column_name]FROMtable......
  • 报错Module was compiled with an incompatible version of Kotlin. The binary versi
    报错ModulewascompiledwithanincompatibleversionofKotlin.Thebinaryversionofitsmetadatais1.8.0,expectedversionis1.6.0.报错原因Kotlin的编译链版本不对ModulewascompiledwithanincompatibleversionofKotlin.Thebinaryversionofitsmet......
  • C# .NET的BinaryFormatter、protobuf-net、Newtonsoft.Json以及自己写的序列化方法序
    https://www.cnblogs.com/s0611163/p/11872484.html测试结果整理后: 结论:1、这几个工具中,protobuf-net序列化和反序列化效率是最快的2、BinaryFormatter和Newtonsoft.Json反序列化慢的比较多3、Newtonsoft.Json序列化后的文件体积比较大4、Newtonsoft.Json在序列化反序列......
  • Binary Tree Level Order Traversal II
    SourceGivenabinarytree,returnthebottom-uplevelordertraversalofitsnodes'values.(ie,fromlefttoright,levelbylevelfromleaftoroot).ExampleGivenbinarytree{3,9,20,#,#,15,7},3/\920/\157return......
  • CF1861C-Queries-for-the-Array-题解
    title:CF1861CQueriesfortheArray题解date:2023-09-0607:53:53categories:-题解因为插入和删除操作都在队尾,所以对序列前缀分析一下:若一个序列的答案为YES,那么它前缀的答案也为YES。(对于没检查过的序列)若一个序列的答案为NO,那么它前缀的答案不确定。(对于没......