大佬的bitset用法小结 https://www.cnblogs.com/zwfymqz/p/8696631.html

BZOJ3687简单题

题意:求子集的算术和的异或和,子集大小为n(n<=1000),所有数和sum<=2000000

  • 求子集和可以用01背包的那个动规,f[i]表示有多少个子集和为i 。时间复杂度O(n*sum)
  • 但是只求异或和就只表示奇偶性,所以bit[i]表示和为i的子集个数的奇偶性。
  • 时间复杂度降为O(n*sum/机器字长)
  • 代码:
     #include <bits/stdc++.h>
    #define nmax 10010
    #define f(a,b) for(int i=a; i<=b; i++) using namespace std;
    typedef long long ll; int main(){
    bitset<> bit;
    bit[] = ;
    int n, x;
    int ans = ;
    cin >> n;
    f(, n) {
    scanf("%d", &x);
    bit ^= (bit << x);
    }
    f(,) if(bit[i]) ans^=i;
    cout << ans << endl;
    return ;
    }

    (╹ڡ╹ )

HDU5036Explosion

  • 求期望:先求出有多少个点能够到达点i :cnt[i],期望就等于$\sum_{i=1}^n cnt[i]$
  • 这样求是因为:考虑使用在第i个门上的炸弹数量期望,要把第i个门弄开,可以有cnt[i]中爆炸选择,所以直接炸i的概率就是 1/cnt[i] ,根据期望的线性性质,所有门求和即得总的炸弹数量
  • 但是这样还是不是很清楚为啥就是期望,因为可能每个门的出现不是均匀的,,,有木有路过的大佬能说一下呀~
  • 所以用bitset优化floyd求传统闭包
  • 代码:
     #include <bits/stdc++.h>
    #define nmax 1010
    #define f(c, a, b) for (int c=a; c<=b; c++) using namespace std;
    int n;
    bitset <nmax> d[nmax]; void floyd(){ f(k, , n) f(i, , n) if(d[i][k]) d[i]|=d[k]; } void init(){ f(i,,n) { d[i].reset(); d[i][i]=; } } int main(){
    int t;
    cin >> t;
    f(cas, , t) {
    scanf("%d", &n);
    init();
    int ys, v;
    double ans=;
    f(i, , n) {
    scanf("%d", &ys);
    f(j, , ys) {
    scanf("%d", &v);
    d[v][i] = ;
    }
    }
    floyd();
    f(i,,n) ans += 1.0/d[i].count();
    printf("Case #%d: %.5lf\n", cas, ans);
    }
    return ;
    }

    bitset刷题记录的更多相关文章

    1. $2019$ 暑期刷题记录1:(算法竞赛DP练习)

      $ 2019 $ 暑期刷题记录: $ POJ~1952~~BUY~LOW, BUY~LOWER: $ (复杂度优化) 题目大意:统计可重序列中最长上升子序列的方案数. 题目很直接的说明了所求为 $ L ...

    2. PE刷题记录

      PE刷题记录 PE60 / 20%dif 这道题比较坑爹. 所有可以相连的素数可以构成一张图,建出这张图,在其中找它的大小为5的团.注意上界的估算,大概在1W以内.1W内有1229个素数,处理出这些素 ...

    3. leetcode刷题记录--js

      leetcode刷题记录 两数之和 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但 ...

    4. Leetcode刷题记录(python3)

      Leetcode刷题记录(python3) 顺序刷题 1~5 ---1.两数之和 ---2.两数相加 ---3. 无重复字符的最长子串 ---4.寻找两个有序数组的中位数 ---5.最长回文子串 6- ...

    5. 刷题记录:[HarekazeCTF2019]encode_and_encode

      目录 刷题记录:[HarekazeCTF2019]encode_and_encode 一.知识点 JSON转义字符绕过 php伪协议 刷题记录:[HarekazeCTF2019]encode_and_ ...

    6. 刷题记录:[De1CTF 2019]Giftbox && Comment

      目录 刷题记录:[De1CTF 2019]Giftbox && Comment 一.知识点 1.sql注入 && totp 2.RCE 3.源码泄露 4.敏感文件读取 ...

    7. 刷题记录:[强网杯 2019]Upload

      目录 刷题记录:[强网杯 2019]Upload 一.知识点 1.源码泄露 2.php反序列化 刷题记录:[强网杯 2019]Upload 题目复现链接:https://buuoj.cn/challe ...

    8. 刷题记录:[XNUCA2019Qualifier]EasyPHP

      目录 刷题记录:[XNUCA2019Qualifier]EasyPHP 解法一 1.error_log结合log_errors自定义错误日志 2.include_path设置包含路径 3.php_va ...

    9. 刷题记录:[DDCTF 2019]homebrew event loop

      目录 刷题记录:[DDCTF 2019]homebrew event loop 知识点 1.逻辑漏洞 2.flask session解密 总结 刷题记录:[DDCTF 2019]homebrew ev ...

    随机推荐

    1. Linux下静态ip的配置

      ------------恢复内容开始------------ TYPE=Ethernet BOOTPROTO=static#dhcp改为static,采用静态方式 DEFROUTE=yes IPV4_ ...

    2. 每日一练_PAT_B1001

      鲁宾逊先生有一只宠物猴,名叫多多.这天,他们两个正沿着乡间小路散步,突然发现路边的告示牌上贴着一张小小的纸条:“欢迎免费品尝我种的花生!——熊字”.鲁宾逊先生和多多都很开心,因为花生正是他们的最爱.在 ...

    3. WeChall_Prime Factory (Training, Math)Training: WWW-Robots (HTTP, Training)

      In this little training challenge, you are going to learn about the Robots_exclusion_standard.The ro ...

    4. 开发中常见的common.js--1

      common.js 1.基于代码重用的目的,方便在页面中调用: 2.跟普通的js包含文件并没有其他不一样,主要是一些js经常用到的函数,或者字符串.数组方法的简单扩展: 3.封装的兼容性的方法.[po ...

    5. DataGuard---->主库和备库都配置 db_file_name_convert和log_file_name_convert的作用

      一.参数说明 [1] db_file_name_convert db_file_name_convert 主数据库和备用数据库的数据文件转换目录对映(如果两数据库的目录结构不一样),如果有多个对映,逐 ...

    6. github三步走(init;add . ;commit -m "提交说明")

      掌握以下几点就基本能满足你平时使用了.按这个顺序来1.git安装,已经好了,略 -到这里本地代码推送到远程已经结束了 2.git本地命令操作-shift+右键-git init:初始化git环境-新建 ...

    7. RTEMS进程同步机制

      互斥量 好像没有互斥量,信号量接收那儿有个图,互斥量似乎术语一类特殊的信号量. 信号量 12. Semaphore Manager 12.1. Introduction The semaphore m ...

    8. logstash 安装插件multiline

      一.安装multiline 在使用elk 传输记录 java 日志时,如下 一个java的报错 在elk中会按每一行 产生多条记录,不方便查阅 这里修改配置文件 使用  multiline   插件 ...

    9. docker 镜像save和转换

      docker save出来的tar包转成镜像 $ docker load < busybox.tar.gz 使用import转的镜像里面是空的,无法启动 报错如下Error: Error res ...

    10. Hello Rust!

      准备工作 Rust是系统编程语言,会经过传统的编译.链接.生成可执行文件等过程.它依赖c/cpp的编译环境,需要提前安装c/cpp开发环境,比如安装gcc及其依赖等. 安装(macOS / Linux ...