2023-08-05 reqwest に Pull Request / ABC313 に参加した / エイシング プログラミング コンテスト 2020 A, B, C, D を解いた
seanmonstar/reqwest に PR した https://github.com/seanmonstar/reqwest/pull/1928 。先日の PR (2023-08-03) が CI で落ちてしまったので、その修正をするもの。
bouzuya/tsukota のスクリプト用環境の整備中。とりあえず管理用に任意のユーザーの account に任意のユーザーを owner として追加するスクリプトを追加してみた。
ABC313 に参加。 A, B, C を解いた。 D 問題のインタラクティブ問題に困った。インタラクティブ問題は楽しくない。 https://atcoder.jp/users/bouzuya/history/share/abc313 。一応 1313 で Highest に並んでいるけど、なんだかなあ……。
エイシング プログラミング コンテスト 2020
- A - Number of Multiples
https://atcoder.jp/contests/aising2020/tasks/aising2020_a- 提出: https://atcoder.jp/contests/aising2020/submissions/44239726
- (r / d) - ((l - 1) / d)
 
- B - An Odd Problem
https://atcoder.jp/contests/aising2020/tasks/aising2020_b- 提出: https://atcoder.jp/contests/aising2020/submissions/44239736
- 指示通りに条件を満たすものを数えれば良い
 
- C - XYZ Triplets
https://atcoder.jp/contests/aising2020/tasks/aising2020_c- 提出: https://atcoder.jp/contests/aising2020/submissions/44239780
- x * xなどが含まれているので- x <= 100までを数えれば十分
- x,- y,- zをそれぞれ- 1..=100の範囲で数えれば間に合う
 
- D - Anything Goes to Zero
https://atcoder.jp/contests/aising2020/tasks/aising2020_d- 提出: https://atcoder.jp/contests/aising2020/submissions/44240791
- 解説 AC
- 一回操作すれば後は f(n)を愚直に確認できる
- 初期状態から 1が popcount は一つ増えるか一つ減るかしかない
- popcount の増減のそれぞれについて総和と 2^i の剰余を前計算すれば間に合う
- 初期状態の popcount が 0, 1 になるケースに注意が必要 (1RE1WA)
 
- E - Camel Train
https://atcoder.jp/contests/aising2020/tasks/aising2020_e- 未着手
 
- F - Two Snuke
https://atcoder.jp/contests/aising2020/tasks/aising2020_f- 未着手
 
use proconio::{input, marker::Bytes};
fn popcount(n: usize) -> usize {
    n.count_ones() as usize
}
fn f(mut n: usize) -> usize {
    let mut count = 0_usize;
    while n != 0 {
        n = n % popcount(n);
        count += 1;
    }
    count
}
fn main() {
    input! {
        n: usize,
        x: Bytes,
    };
    let x = x
        .into_iter()
        .map(|b| (b - b'0') as usize)
        .collect::<Vec<usize>>();
    let pc_x = x.iter().filter(|&&x_i| x_i == 1).count();
    if pc_x == 0 {
        for _ in 0..n {
            println!("1");
        }
        return;
    }
    let sum = {
        let mut r0 = 0_usize;
        for x_i in x.iter().copied() {
            r0 <<= 1;
            r0 += x_i;
            r0 %= pc_x + 1;
        }
        let mut r1 = 0_usize;
        if pc_x > 1 {
            for x_i in x.iter().copied() {
                r1 <<= 1;
                r1 += x_i;
                r1 %= pc_x - 1;
            }
        }
        vec![r0, r1]
    };
    // pow[i][j] := 2.pow(j) % (pc_x + if i == 0 { 1 } else { -1 })
    let pow = {
        let mut pow = vec![vec![0; n]; 2];
        let mut p = 1_usize;
        for i in 0..n {
            pow[0][i] = p;
            p <<= 1;
            p %= pc_x + 1;
        }
        if pc_x > 1 {
            let mut p = 1_usize;
            for i in 0..n {
                pow[1][i] = p;
                p <<= 1;
                p %= pc_x - 1;
            }
        }
        pow
    };
    let mut ans = vec![0; n];
    for (i, x_i) in x.iter().copied().enumerate() {
        match x_i {
            0 => {
                let pc = pc_x + 1;
                let sum = (sum[x_i] + pow[x_i][n - 1 - i]) % pc;
                ans[i] = f(sum) + 1;
            }
            1 => {
                let pc = pc_x - 1;
                if pc == 0 {
                    ans[i] = 0;
                    continue;
                }
                let sum = (pc + sum[x_i] - pow[x_i][n - 1 - i]) % pc;
                ans[i] = f(sum) + 1;
            }
            _ => unreachable!(),
        }
    }
    for a in ans {
        println!("{}", a);
    }
}
今日のコミット。
- tsukota 9 commits
- rust-atcoder 2 commits