結果
問題 | No.1421 国勢調査 (Hard) |
ユーザー |
![]() |
提出日時 | 2021-03-05 22:30:22 |
言語 | Rust (1.83.0 + proconio) |
結果 |
AC
|
実行時間 | 10 ms / 2,000 ms |
コード長 | 2,392 bytes |
コンパイル時間 | 13,519 ms |
コンパイル使用メモリ | 387,636 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-10-07 03:05:13 |
合計ジャッジ時間 | 15,662 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 30 |
ソースコード
// ---------- begin scannner ----------#[allow(dead_code)]mod scanner {use std::str::FromStr;pub struct Scanner<'a> {it: std::str::SplitWhitespace<'a>,}impl<'a> Scanner<'a> {pub fn new(s: &'a String) -> Scanner<'a> {Scanner {it: s.split_whitespace(),}}pub fn next<T: FromStr>(&mut self) -> T {self.it.next().unwrap().parse::<T>().ok().unwrap()}pub fn next_bytes(&mut self) -> Vec<u8> {self.it.next().unwrap().bytes().collect()}pub fn next_chars(&mut self) -> Vec<char> {self.it.next().unwrap().chars().collect()}pub fn next_vec<T: FromStr>(&mut self, len: usize) -> Vec<T> {(0..len).map(|_| self.next()).collect()}}}// ---------- end scannner ----------use std::io::Write;fn main() {use std::io::Read;let mut s = String::new();std::io::stdin().read_to_string(&mut s).unwrap();let mut sc = scanner::Scanner::new(&s);let out = std::io::stdout();let mut out = std::io::BufWriter::new(out.lock());run(&mut sc, &mut out);}fn run<W: Write>(sc: &mut scanner::Scanner, out: &mut std::io::BufWriter<W>) {let n: usize = sc.next();let m: usize = sc.next();let mut cond = vec![];for _ in 0..m {let a: usize = sc.next();let mut b = 0u64;for _ in 0..a {let k = sc.next::<usize>() - 1;b |= 1 << k;}let y: u32 = sc.next();cond.push((b, y));}let mut base: Vec<(u64, u32)> = vec![];for &(mut b, mut y) in cond.iter() {for &(p, q) in base.iter() {if b > (b ^ p) {b ^= p;y ^= q;}}if b > 0 {base.push((b, y));} else if y > 0 {println!("-1");return;}}base.sort();let mut ans = vec![0; n];for i in 0..base.len() {let (b, y) = base[i];for (j, base) in base.iter_mut().enumerate() {if i != j && base.0 > b ^ base.0 {base.0 ^= b;base.1 ^= y;}}let k = 64 - b.leading_zeros() as usize;ans[k - 1] = y;}for a in ans {writeln!(out, "{}", a).ok();}}