結果
問題 | No.701 ひとりしりとり |
ユーザー | machikox |
提出日時 | 2019-04-25 13:13:00 |
言語 | Rust (1.77.0 + proconio) |
結果 |
WA
|
実行時間 | - |
コード長 | 2,310 bytes |
コンパイル時間 | 13,030 ms |
コンパイル使用メモリ | 379,476 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-04-29 17:37:21 |
合計ジャッジ時間 | 13,034 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 1 ms
5,248 KB |
testcase_01 | AC | 1 ms
5,248 KB |
testcase_02 | AC | 1 ms
5,376 KB |
testcase_03 | AC | 1 ms
5,376 KB |
testcase_04 | AC | 1 ms
5,376 KB |
testcase_05 | AC | 1 ms
5,376 KB |
testcase_06 | AC | 1 ms
5,376 KB |
testcase_07 | AC | 1 ms
5,376 KB |
testcase_08 | AC | 1 ms
5,376 KB |
testcase_09 | AC | 1 ms
5,376 KB |
testcase_10 | AC | 1 ms
5,376 KB |
testcase_11 | WA | - |
ソースコード
use std::io::{self, BufRead, Write}; const ABC: [char; 26] = ['a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z']; const START: [char; 25] = ['a','b','c','d','e','f','g','h','i','j','k','l','m','o','p','q','r','s','t','u','v','w','x','y','z']; const END: [char; 25] = ['b','c','d','e','f','g','h','i','j','k','l','m','o','p','q','r','s','t','u','v','w','x','y','z','a']; fn get_lines() -> Vec<String> { let stdin = io::stdin(); let lines: Vec<String> = stdin.lock().lines().map(|l| l.unwrap()).collect(); return lines; } fn main(){ let stdout = io::stdout(); let mut bufout = io::BufWriter::new(stdout.lock()); let s = &get_lines(); let n = s[0].parse::<i32>().unwrap(); if n == 1 { writeln!(bufout, "n").unwrap(); return; } let mut i = 1; for (s, e) in START.iter().zip(END.iter()) { if i == n { writeln!(bufout, "{}n", s).unwrap(); return; } writeln!(bufout, "{}{}", s, e).unwrap(); i += 1; } let mut j = 1; while j <= 18 { let mut k = 0; let mut t = String::with_capacity(j + 2); for x in 0..j { for _ in 0..26 { for (s, e) in START.iter().zip(END.iter()) { if i == n { writeln!(bufout, "{}n", s).unwrap(); return; } t.clear(); t.push(*s); for _ in 0..x { if k == 26 { k = 0; } t.push(ABC[k]); k += 1; } for _ in 0..x { if k == 26 { k = 0; } k += 1; } if k == 26 { k = 0; } let mut l = k; for _ in 0..(j - x) { if l == 26 { l = 0; } t.push(ABC[l]); l += 1; } k += 1; t.push(*e); writeln!(bufout, "{}", t).unwrap(); i += 1; } } } j += 1; } println!("{}", i) }