1 unstable release

0.1.0 Jun 27, 2019

#2199 in Data structures

Download history 194/week @ 2023-12-18 140/week @ 2023-12-25 91/week @ 2024-01-01 199/week @ 2024-01-08 235/week @ 2024-01-15 170/week @ 2024-01-22 100/week @ 2024-01-29 147/week @ 2024-02-05 175/week @ 2024-02-12 200/week @ 2024-02-19 251/week @ 2024-02-26 231/week @ 2024-03-04 185/week @ 2024-03-11 282/week @ 2024-03-18 359/week @ 2024-03-25 334/week @ 2024-04-01

1,190 downloads per month
Used in 3 crates

MIT license

13KB
378 lines

bitset-fixed

Bitset for DP.

Example

Example for AGC20-C

use bitset_fixed::BitSet;
use rand::prelude::*;

fn main() {
    let mut rng = StdRng::seed_from_u64(114514);

    let n: Vec<usize> = (0..25).map(|_| rng.next_u32() as usize % 2000).collect();
    let sum = n.iter().sum::<usize>();

    let mut bitset = BitSet::new(sum + 1);
    bitset.set(0, true);

    for &x in &n {
        bitset |= &(&bitset << x);
    }

    let ans = ((sum + 1) / 2..).find(|&i| bitset[i]).unwrap();

    println!("N = {:?}\nAnswer = {}", n, ans);
}

No runtime deps