結果

問題 No.893 お客様を誘導せよ
ユーザー phsplsphspls
提出日時 2020-01-08 18:16:33
言語 Rust
(1.77.0)
結果
AC  
実行時間 15 ms / 2,000 ms
コード長 1,056 bytes
コンパイル時間 11,882 ms
コンパイル使用メモリ 378,968 KB
実行使用メモリ 9,472 KB
最終ジャッジ日時 2024-05-02 13:00:12
合計ジャッジ時間 12,918 ms
ジャッジサーバーID
(参考情報)
judge4 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
5,248 KB
testcase_01 AC 1 ms
5,376 KB
testcase_02 AC 3 ms
5,376 KB
testcase_03 AC 7 ms
5,504 KB
testcase_04 AC 8 ms
5,376 KB
testcase_05 AC 7 ms
5,376 KB
testcase_06 AC 5 ms
5,376 KB
testcase_07 AC 1 ms
5,376 KB
testcase_08 AC 15 ms
9,472 KB
testcase_09 AC 1 ms
5,376 KB
testcase_10 AC 1 ms
5,376 KB
testcase_11 AC 1 ms
5,376 KB
testcase_12 AC 1 ms
5,376 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

use std::io::Read;
use std::collections::VecDeque;

fn solve(count: usize, registers: &mut Vec<VecDeque<u32>>) {
    let mut result: Vec<u32> = vec![];
    while result.len() < count {
        registers.iter_mut()
            .filter(|r| !r.is_empty())
            .for_each(|r| {
                result.push(r.pop_front().unwrap());
            });
    }
    println!("{}", result.iter().map(|v| v.to_string()).collect::<Vec<String>>().join(" "));
}

fn main() {
    let mut all_data = String::new();
    std::io::stdin().read_to_string(&mut all_data).ok();
    let all_data: Vec<&str> = all_data.trim().split('\n').map(|s| s.trim()).collect();
    let n: u32 = all_data.iter().next().unwrap().parse::<u32>().unwrap();
    let mut registers: Vec<VecDeque<u32>> = all_data.iter().skip(1).take(n as usize)
        .map(|c| c.split_whitespace().skip(1).map(|v| v.parse::<u32>().unwrap()).collect::<VecDeque<u32>>())
        .filter(|l| !l.is_empty())
        .collect();
    let count = registers.iter().flatten().count();
    solve(count, &mut registers);
}
0