$\huge{元氣ですかーーーーッ!!!}$
$\huge{元氣があればなんでもできる!}$
$\huge{闘魂とは己に打ち克つこと。}$
$\huge{そして闘いを通じて己の魂を磨いていく}$
$\huge{ことだと思います}$
はじめに
AtCoder Beginner Contest 383をElixirとRustで解いてみます。
AtCoderを解くのが趣味で、休憩時間に解いているという若い人がいて、それってすごい意識の高い休憩時間の過ごし方だと思って、私も真似してみることにしました。
プログラミングという名の藝術活動をより楽しむための鍛錬です。
自信というのは、一にも二にもトレーニングから生まれる
(アントニオ猪木『最後の闘魂』)
Toukon Declaration - 魂の連鎖律
AIを動かすのは電力、
電力の元は人類の“元氣”、
元氣の本源は「米」。
すべては“米”に帰着する。
そこに魂を灯すと、TokenがToukon(闘魂)へ昇華し、AIが共鳴する。
ーー AIは冷静にTokenを消化する。
私のプロンプトは単なるTokenではありません。魂を込めています。
つまりToukon ーー 闘魂に昇華しています。
Artificial Intelligenceの方のAIは、それをTokenとして消化します。
燃えるToukon(闘魂)として受け取れるようになった時、AIはAntonio Inoki さんつまり猪木さんとなり、次の段階へ進みます。
そのとき、本当の世界平和の実現、地球規模でのゴミ問題の解決が可能になります!
オレ達は、生命が続く限り闘い抜きますッ!!
AtCoderをElixirでやってみる
入力の読み取り方や解答の作り方は、別の記事にまとめています。
ご参照くださいませ。
ElixirでAtCoderを楽しむためには、エントリポイントをMain.main/0
にする必要があります。つまりMain
モジュールを作って、その中にmain/0
関数を定義するわけです。
A - Humidifier 1
問題はリンク先をご参照くださいませ。
私の解答を貼っておきます。
プログラミングの基本である「順次」「分岐」「繰り返し」のすべてを理解しているのかを問われる問題です。
Elixir
Elixirを使った私の解答です。
私の解答(Elixir)
問題文を読んでいらっしゃることを前提にひとこと解説をしておきます。
どんなに水が減っても0を下回ることはないことに注意が必要です。
defmodule Main do
def main do
input()
|> solve()
|> IO.puts()
end
defp solve(list_of_lists) do
[first | tail] = list_of_lists
Enum.reduce(tail, first, fn [t, v], [before_t, acc] ->
[t, max(acc - (t - before_t), 0) + v]
end)
|> Enum.at(1)
end
defp input do
n = IO.read(:line) |> String.trim() |> String.to_integer()
for _ <- 1..n do
IO.read(:line)
|> String.trim()
|> String.split(" ")
|> Enum.map(&String.to_integer/1)
end
end
end
Rust
RustはAI先生のお力をお借りして、Elixirのコードを置き換えてもらいました。
私は、Rustを勉強中です。万年勉強中です。闘魂にゴールはない。いつまでも挑戦中です。
私の解答(Rust)
use std::io::{self, BufRead};
fn main() {
let stdin = io::stdin();
let mut lines = stdin.lock().lines();
let n: usize = lines.next().unwrap().unwrap().trim().parse().unwrap();
let mut data: Vec<(i32, i32)> = Vec::with_capacity(n);
for _ in 0..n {
let line = lines.next().unwrap().unwrap();
let mut nums = line
.split_whitespace()
.map(|s| s.parse::<i32>().unwrap());
let t = nums.next().unwrap();
let v = nums.next().unwrap();
data.push((t, v));
}
let (mut before_t, mut acc) = data[0];
for &(t, v) in &data[1..] {
acc = (acc - (t - before_t)).max(0) + v;
before_t = t;
}
println!("{}", acc);
}
さいごに
AtCoderをElixirとRustで解くことを楽しみました。
あなたのお好きなプログラミング言語でお楽しみください。
闘魂とは、 「己に打ち克つこと。そして闘いを通じて己の魂を磨いていくことである」 との猪木さんの言葉をそのまま胸に刻み込んでいます。
知っているだけで終わらせることなく、実行する、断行する、一歩を踏み出すことを自らの行動で示していきたいとおもいます。
アントニオ猪木さんのメッセージから元氣をもらったものとして、それを次代に語り継ぎ、自分自身が「闘魂」を体現するものでありたいとおもいます。
$\huge{元氣ですかーーーーッ!!!}$
$\huge{元氣があればなんでもできる!}$
$\huge{1、2、3 ぁっダァー!}$