$\huge{元氣ですかーーーーッ!!!}$
$\huge{元氣があればなんでもできる!}$
$\huge{闘魂とは己に打ち克つこと。}$
$\huge{そして闘いを通じて己の魂を磨いていく}$
$\huge{ことだと思います}$
はじめに
AtCoder Beginner Contest 402をElixirとRustで解いてみます。
AtCoderを解くのが趣味で、休憩時間に解いているという若い人がいて、それってすごい意識の高い休憩時間の過ごし方だと思って、私も真似してみることにしました。
プログラミングという名の芸術活動をより楽しむための鍛錬です。
自信というのは、一にも二にもトレーニングから生まれる
(アントニオ猪木『最後の闘魂』)
AtCoderをElixirでやってみる
入力の読み取り方や解答の作り方は、別の記事にまとめています。
ご参照くださいませ。
ElixirでAtCoderを楽しむためには、エントリポイントをMain.main/0
にする必要があります。つまりMain
モジュールを作って、その中にmain/0
関数を定義するわけです。
B - Restaurant Queue
問題はリンク先をご参照くださいませ。
私の解答を貼っておきます。
プログラミングの基本である「順次」「分岐」「繰り返し」のうち、これらすべてを理解できているのかを問う問題です。
Elixir
Elixirを使った私の解答です。
私の解答(Elixir)
問題文を読んでいらっしゃることを前提にひとこと解説をしておきます。
キューを使う問題です。Erlangのqueueをはじめて使ってみました。
defmodule Main do
def main do
q = IO.read(:line) |> String.trim() |> String.to_integer()
list_of_lists = for _ <- 1..q do
IO.read(:line)
|> String.trim()
|> String.split(" ")
|> Enum.map(&String.to_integer/1)
end
solve(list_of_lists)
|> IO.puts()
end
def solve(list_of_lists) do
list_of_lists
|> Enum.reduce({[], :queue.new()}, fn
[1, x], {acc_output, acc_queue} -> {acc_output, :queue.in(x, acc_queue)}
[2], {acc_output, acc_queue} ->
{{:value, x}, new_queue} = :queue.out(acc_queue)
{[x | acc_output], new_queue}
end)
|> elem(0)
|> Enum.reverse()
|> Enum.join("\n")
end
end
Rust
RustはAI先生のお力をお借りして、Elixirのコードを置き換えてもらいました。
私は、Rustを勉強中です。万年勉強中です。闘魂にゴールはない。いつまでも挑戦中です。
私の解答(Rust)
use std::collections::VecDeque;
use std::io::{self, BufRead};
fn main() {
let stdin = io::stdin();
let mut lines = stdin.lock().lines();
let q: usize = lines.next().unwrap().unwrap().trim().parse().unwrap();
let mut queue: VecDeque<i32> = VecDeque::new();
let mut output: Vec<i32> = Vec::new();
for _ in 0..q {
let line = lines.next().unwrap().unwrap();
let parts: Vec<&str> = line.trim().split_whitespace().collect();
match parts.as_slice() {
["1", x] => {
let x: i32 = x.parse().unwrap();
queue.push_back(x);
}
["2"] => {
let value = queue.pop_front().expect("Something went wrong");
output.push(value);
}
_ => panic!("Invalid input line"),
}
}
for val in output {
println!("{}", val);
}
}
さいごに
AtCoder Beginner Contest 402をElixirとRustで解くことを楽しみました。
あなたのお好きなプログラミング言語でお楽しみください。
闘魂とは、 「己に打ち克つこと。そして闘いを通じて己の魂を磨いていくことである」 との猪木さんの言葉をそのまま胸に刻み込んでいます。
知っているだけで終わらせることなく、実行する、断行する、一歩を踏み出すことを自らの行動で示していきたいとおもいます。
アントニオ猪木さんのメッセージから元氣をもらったものとして、それを次代に語り継ぎ、自分自身が「闘魂」を体現するものでありたいとおもいます。
$\huge{元氣ですかーーーーッ!!!}$
$\huge{元氣があればなんでもできる!}$
$\huge{1、2、3 ぁっダァー!}$