Submission #59857259


Source Code Expand

use itertools::Itertools;
use proconio::{
    input,
    marker::{Chars, Usize1},
};

fn inv(c: char) -> char {
    if b'a' <= c as u8 {
        (b'A' + (c as u8 - b'a')) as char
    } else {
        (b'a' + (c as u8 - b'A')) as char
    }
}

fn dfs(s: &Vec<char>, q: usize, len: usize) -> char {
    if len == s.len() {
        return s[q];
    }

    return if q < len / 2 {
        dfs(s, q, len / 2)
    } else {
        inv(dfs(s, q - len / 2, len / 2))
    };
}

fn main() {
    input! {
        s: Chars,
        q: usize,
        k: [Usize1; q],
    }

    let mut ans = vec![];
    for &x in k.iter() {
        let mut len = s.len();
        while len <= x {
            len *= 2;
        }
        ans.push(dfs(&s, x, len));
    }
    println!("{}", ans.iter().join(" "));
}

Submission Info

Submission Time
Task D - Strange Mirroring
User ardRiriy
Language Rust (rustc 1.70.0)
Score 350
Code Size 785 Byte
Status AC
Exec Time 85 ms
Memory 9412 KiB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 350 / 350
Status
AC × 3
AC × 63
Set Name Test Cases
Sample sample_01.txt, sample_02.txt, sample_03.txt
All sample_01.txt, sample_02.txt, sample_03.txt, test_01.txt, test_02.txt, test_03.txt, test_04.txt, test_05.txt, test_06.txt, test_07.txt, test_08.txt, test_09.txt, test_10.txt, test_11.txt, test_12.txt, test_13.txt, test_14.txt, test_15.txt, test_16.txt, test_17.txt, test_18.txt, test_19.txt, test_20.txt, test_21.txt, test_22.txt, test_23.txt, test_24.txt, test_25.txt, test_26.txt, test_27.txt, test_28.txt, test_29.txt, test_30.txt, test_31.txt, test_32.txt, test_33.txt, test_34.txt, test_35.txt, test_36.txt, test_37.txt, test_38.txt, test_39.txt, test_40.txt, test_41.txt, test_42.txt, test_43.txt, test_44.txt, test_45.txt, test_46.txt, test_47.txt, test_48.txt, test_49.txt, test_50.txt, test_51.txt, test_52.txt, test_53.txt, test_54.txt, test_55.txt, test_56.txt, test_57.txt, test_58.txt, test_59.txt, test_60.txt
Case Name Status Exec Time Memory
sample_01.txt AC 1 ms 1928 KiB
sample_02.txt AC 1 ms 2048 KiB
sample_03.txt AC 1 ms 2008 KiB
test_01.txt AC 3 ms 2308 KiB
test_02.txt AC 8 ms 4064 KiB
test_03.txt AC 1 ms 2236 KiB
test_04.txt AC 3 ms 3888 KiB
test_05.txt AC 4 ms 4288 KiB
test_06.txt AC 61 ms 8084 KiB
test_07.txt AC 38 ms 6700 KiB
test_08.txt AC 41 ms 7684 KiB
test_09.txt AC 3 ms 2880 KiB
test_10.txt AC 9 ms 3236 KiB
test_11.txt AC 1 ms 2800 KiB
test_12.txt AC 70 ms 7832 KiB
test_13.txt AC 9 ms 2708 KiB
test_14.txt AC 58 ms 7664 KiB
test_15.txt AC 31 ms 5220 KiB
test_16.txt AC 40 ms 7092 KiB
test_17.txt AC 51 ms 8912 KiB
test_18.txt AC 72 ms 7436 KiB
test_19.txt AC 62 ms 6704 KiB
test_20.txt AC 20 ms 3708 KiB
test_21.txt AC 20 ms 4160 KiB
test_22.txt AC 47 ms 7260 KiB
test_23.txt AC 27 ms 5728 KiB
test_24.txt AC 72 ms 7580 KiB
test_25.txt AC 63 ms 7116 KiB
test_26.txt AC 60 ms 7384 KiB
test_27.txt AC 2 ms 2180 KiB
test_28.txt AC 42 ms 6272 KiB
test_29.txt AC 18 ms 4764 KiB
test_30.txt AC 5 ms 2688 KiB
test_31.txt AC 21 ms 5976 KiB
test_32.txt AC 15 ms 5996 KiB
test_33.txt AC 9 ms 6816 KiB
test_34.txt AC 10 ms 6604 KiB
test_35.txt AC 9 ms 6896 KiB
test_36.txt AC 64 ms 8520 KiB
test_37.txt AC 62 ms 8452 KiB
test_38.txt AC 50 ms 8396 KiB
test_39.txt AC 40 ms 8436 KiB
test_40.txt AC 38 ms 9240 KiB
test_41.txt AC 33 ms 9400 KiB
test_42.txt AC 73 ms 8240 KiB
test_43.txt AC 71 ms 8036 KiB
test_44.txt AC 63 ms 8172 KiB
test_45.txt AC 55 ms 9204 KiB
test_46.txt AC 57 ms 8336 KiB
test_47.txt AC 55 ms 9224 KiB
test_48.txt AC 84 ms 8416 KiB
test_49.txt AC 79 ms 8480 KiB
test_50.txt AC 71 ms 8472 KiB
test_51.txt AC 60 ms 8852 KiB
test_52.txt AC 66 ms 8460 KiB
test_53.txt AC 61 ms 9412 KiB
test_54.txt AC 85 ms 8416 KiB
test_55.txt AC 80 ms 8408 KiB
test_56.txt AC 69 ms 8448 KiB
test_57.txt AC 64 ms 8476 KiB
test_58.txt AC 61 ms 8804 KiB
test_59.txt AC 61 ms 9364 KiB
test_60.txt AC 24 ms 6064 KiB