题目地址:CF1097F Alex and a TV Show

bitset+莫比乌斯反演(个人第一道莫比乌斯反演题)

由于只关心出现次数的奇偶性,显然用bitset最合适

但我们并不直接在bitset中存 \(x\) 的个数,而是存 \(x\) 的约数出现的个数

对于操作1,先预处理然后直接赋值

对于操作2,直接 \(xor\)

对于操作3,直接 \(and\)

对于操作4,用莫比乌斯反演处理一下:

设 \(f(x)\) 为 \(x\) 出现的次数, \(g(x)\) 为 \(x\) 作为约数出现的次数

显然有:\(g(x)=\sum_{x|d}\ f(d)\)

因此有:\(f(x)=\sum_{x|d}\ \mu(\frac{d}{x})\ g(x)\)

由于只关心奇偶性, \(\mu(x)=-1\) 相当于 \(\mu(x)=1\) ,因此只需要把 \(\mu(x)=0\) 的找到即可

代码:

#include <bits/stdc++.h>
using namespace std;
const int N = 100006, M = 7006;
bitset<M> a[N], p[M], miu, Miu[M];

void prework(int n) {
    miu.set();
    for (int i = 2; i * i <= n; i++)
        for (int j = 1; i * i * j <= n; j++)
            miu[i*i*j] = 0;
    for (int i = 1; i <= n; i++)
        for (int j = 1; i * j <= n; j++) {
            p[i*j][i] = 1;
            Miu[i][i*j] = miu[j];
        }
}

int main() {
    prework(7000);
    int n, q;
    cin >> n >> q;
    while (q--) {
        int o;
        scanf("%d", &o);
        if (o == 1) {
            int x, v;
            scanf("%d %d", &x, &v);
            a[x] = p[v];
        } else if (o == 2) {
            int x, y, z;
            scanf("%d %d %d", &x ,&y, &z);
            a[x] = a[y] ^ a[z];
        } else if (o == 3) {
            int x, y, z;
            scanf("%d %d %d", &x, &y, &z);
            a[x] = a[y] & a[z];
        } else {
            int x, v;
            scanf("%d %d", &x, &v);
            printf("%d", (a[x] & Miu[v]).count() & 1);
        }
    }
    return 0;
}

CF1097F Alex and a TV Show的更多相关文章

  1. CF1097F Alex and a TV Show 莫比乌斯反演、bitset

    传送门 发现自己对mobius反演的理解比较浅显-- 首先我们只需要维护每一个数的出现次数\(\mod 2\)的值,那么实际上我们只需要使用\(bitset\)进行维护,每一次加入一个数将其对应次数异 ...

  2. 【CF1097F】Alex and a TV Show(bitset)

    [CF1097F]Alex and a TV Show(bitset) 题面 洛谷 CF 题解 首先模\(2\)意义下用\(bitset\)很明显了. 那么问题在于怎么处理那个\(gcd\)操作. 然 ...

  3. 【CF1097F】Alex and a TV Show

    [CF1097F]Alex and a TV Show 题面 洛谷 题解 我们对于某个集合中的每个\(i\),令\(f(i)\)表示\(i\)作为约数出现次数的奇偶性. 因为只要因为奇偶性只有\(0, ...

  4. 【Codeforces 1097F】Alex and a TV Show(bitset & 莫比乌斯反演)

    Description 你需要维护 \(n\) 个可重集,并执行 \(m\) 次操作: 1 x v:\(X\leftarrow \{v\}\): 2 x y z:\(X\leftarrow Y \cu ...

  5. 题解 CF1097F 【Alex and a TV Show】

    妙妙题-- 这道题这要求%2的个数,肯定有什么性质 于是我们想到了用\(bitset\)来处理 由于三操作有\(gcd\),于是我们又想到用反演来解决 我们回忆一下反演的柿子 设\(f(x)\)为x出 ...

  6. CodeForces - 1097F:Alex and a TV Show (bitset & 莫比乌斯容斥)

    Alex decided to try his luck in TV shows. He once went to the quiz named "What's That Word?!&qu ...

  7. Codeforces 1097 Alex and a TV Show

    传送门 除了操作 \(3\) 都可以 \(bitset\) 现在要维护 \[C_i=\sum_{gcd(j,k)=i}A_jB_k\] 类比 \(FWT\),只要求出 \(A'_i=\sum_{i|d ...

  8. Codeforces 1097F Alex and a TV Show (莫比乌斯反演)

    题意:有n个可重集合,有四种操作: 1:把一个集合设置为单个元素v. 2:两个集合求并集. 3:两个集合中的元素两两求gcd,然后这些gcd形成一个集合. 4:问某个可重复集合的元素v的个数取模2之后 ...

  9. Codeforces 1097F. Alex and a TV Show

    传送门 由于只要考虑 $\mod 2$ 意义下的答案,所以我们只要维护一堆的 $01$ 容易想到用 $bitset$ 瞎搞...,发现当复杂度 $qv/32$ 是可以过的... 一开始容易想到对每个集 ...

随机推荐

  1. MyBatis-Configuration

    一.引用 properties 配置文件 db.properties driver=com.mysql.cj.jdbc.Driver url=jdbc:mysql://192.168.8.136:33 ...

  2. Linux-CentOS 查看(监控)服务器网卡流量

    1.使用系统自带的命令: watch more /proc/net/dev 2. 使用nload命令,需要自行安装 1)# yum install flex byacc libpcap ncurses ...

  3. Ubuntu 云服务器上部署自己的 Rails 应用

    自学rails一段时间了,之前只用heroku部署了网站,想尝试把网站以一个更“正经”的方式呈现出来,就买了一个阿里云服务器.参考了网上部分rails部署教程,过程中也遇到了一些问题,所以在完成之后总 ...

  4. golang os包使用笔记

    zhangsan os.Stidn 标准输入 os.Stdout 标准输出 os.Stderr 标准错误输出

  5. dubbo监控中心---dubbo-admin

    dubbo监控中心---dubbo-admin: 一:dubbo管理平台搭建: 1-1:下载dubbo-admin.war包 https://pan.baidu.com/s/16jkoSozY68M7 ...

  6. 657. Robot Return to Origin

    Description There is a robot starting at position (0, 0), the origin, on a 2D plane. Given a sequenc ...

  7. C#窗口编程时TextBox中的换行

    注意Windows下的换行符是\r\n.只使用\n是无法完成换行的

  8. IIS7.5配置过程

    1.Windows功能,注意选择应用程序开发功能,否则不能使用经典模式. 2.Cmd运行(使用.netframework4.0)C:\Windows\Microsoft.NET\Framework\V ...

  9. Python中json一点小知识

    import json dic={ "name":"杨林" } ret=json.dumps(dic,ensure_ascii=False) #因为json.d ...

  10. HTML 实例学习(基础)

    1.HTML <html> 标签 注意:对于中文网页需要使用 <meta charset="utf-8"> 声明编码,否则会出现乱码.有些浏览器会设置 GB ...