aboutsummaryrefslogtreecommitdiffhomepage
path: root/archive/q/brainf-ck/a/50/index.html
diff options
context:
space:
mode:
Diffstat (limited to 'archive/q/brainf-ck/a/50/index.html')
-rw-r--r--archive/q/brainf-ck/a/50/index.html147
1 files changed, 147 insertions, 0 deletions
diff --git a/archive/q/brainf-ck/a/50/index.html b/archive/q/brainf-ck/a/50/index.html
new file mode 100644
index 0000000..5393d3c
--- /dev/null
+++ b/archive/q/brainf-ck/a/50/index.html
@@ -0,0 +1,147 @@
+<!DOCTYPE html>
+<html>
+ <head>
+ <meta name="viewport" content="width=device-width, initial-scale=1">
+ <title>問題 #3 - 回答 #50 | Albatross.PHP</title>
+ <link rel="stylesheet" href="../../../../assets/index.css">
+ <link rel="icon" type="image/svg+xml" href="../../../../assets/favicon.svg">
+ <script type="module" src="../../../../assets/index.js"></script>
+ </head>
+ <body>
+ <header class="container">
+ <nav class="navbar">
+ <a class="navbar-brand" href="../../../../index.html">Albatross.PHP</a>
+ </nav>
+ </header>
+ <main class="container mt-5">
+ <h1 class="mb-4">問題 #3 - 回答 #50</h1>
+ <nav>
+ <ol class="breadcrumb">
+ <li class="breadcrumb-item"><a href="../../../../index.html">問題一覧</a></li>
+ <li class="breadcrumb-item"><a href="../../index.html">Brainf*ck</a></li>
+ <li class="breadcrumb-item"><a href="../index.html">回答一覧</a></li>
+ <li class="breadcrumb-item active">#50</li>
+ </ol>
+ </nav>
+
+ <h2>Brainf*ck</h2>
+ <p>
+ Brainf*ck を実装してください。標準入力から Brainf*ck のソースコードが渡されます。Brainf*ck の仕様のうち、入力命令である「,」は未実装で構いません。
+
+一部明確に挙動が定められていない部分については、以下の仕様とします。
+メモリの各セルは 8 bit の符号なし整数です。今回の入力でオーバーフローは発生しません。
+メモリのアドレスは非負整数です。今回の入力で負のアドレスへポインタを動かすことはありません。
+Brainf*ck に存在する命令以外の文字を受け取った場合は無視してください。
+今回の入力に不正なプログラムは含まれません。すなわち、「[」と「]」は必ず釣り合っています。
+ </p>
+ <h2>回答 #50</h2>
+ <p>
+ hanhan1978 が 2024-03-08 16:05:40 に投稿
+ </p>
+ <h2>コード</h2>
+ <p>
+ 888 byte
+ </p>
+ <pre><code class="hljs language-php">$s = stream_get_contents(STDIN);
+$pc = 0;
+$m = [];
+$p = 0;
+
+while ($pc &lt; strlen($s)) {
+ switch ($s[$pc]) {
+ case &#039;&gt;&#039;:
+ $p++;
+ break;
+ case &#039;&lt;&#039;:
+ $p--;
+ break;
+ case &#039;+&#039;:
+ if (!isset($m[$p])) {
+ $m[$p] = 0;
+ }
+ $m[$p]++;
+ break;
+ case &#039;-&#039;:
+ if (!isset($m[$p])) {
+ $m[$p] = 0;
+ }
+ $m[$p]--;
+ break;
+ case &#039;.&#039;:
+ echo chr($m[$p]);
+ break;
+ case &#039;[&#039;:
+ if (!isset($m[$p]) || $m[$p] === 0) {
+ $d = 1;
+ while ($d &gt; 0) {
+ $pc++;
+ if ($s[$pc] === &#039;[&#039;) {
+ $d++;
+ } elseif ($s[$pc] === &#039;]&#039;) {
+ $d--;
+ }
+ }
+ }
+ break;
+ case &#039;]&#039;:
+ if (isset($m[$p]) &amp;&amp; $m[$p] !== 0) {
+ $d = 1;
+ while ($d &gt; 0) {
+ $pc--;
+ if ($s[$pc] === &#039;]&#039;) {
+ $d++;
+ } elseif ($s[$pc] === &#039;[&#039;) {
+ $d--;
+ }
+ }
+ }
+ break;
+ }
+ $pc++;
+}</code></pre>
+ <h2>実行結果</h2>
+ <div class="js-phper-token">
+ </div>
+ <div class="mt-3">
+ ステータス: <span class="js-aggregated-execution-status" data-answer-id="261">OK</span>
+ </div>
+ <div class="mt-3">
+ <h3>テストケース 1</h3>
+ <div>
+ ステータス: <span class="js-testcase-execution-status" data-testcase-execution-id="635">OK</span>
+ </div>
+ <h4>標準出力</h4>
+ <pre><code class="js-testcase-execution-stdout hljs language-plaintext" data-testcase-execution-id="635">Hello World!
+
+</code></pre>
+ <h4>標準エラー出力</h4>
+ <pre><code class="js-testcase-execution-stderr hljs language-plaintext" data-testcase-execution-id="635">
+</code></pre>
+ <h3>テストケース 2</h3>
+ <div>
+ ステータス: <span class="js-testcase-execution-status" data-testcase-execution-id="636">OK</span>
+ </div>
+ <h4>標準出力</h4>
+ <pre><code class="js-testcase-execution-stdout hljs language-plaintext" data-testcase-execution-id="636">PHPerKaigi 2024
+</code></pre>
+ <h4>標準エラー出力</h4>
+ <pre><code class="js-testcase-execution-stderr hljs language-plaintext" data-testcase-execution-id="636">
+</code></pre>
+ <h3>テストケース 3</h3>
+ <div>
+ ステータス: <span class="js-testcase-execution-status" data-testcase-execution-id="637">OK</span>
+ </div>
+ <h4>標準出力</h4>
+ <pre><code class="js-testcase-execution-stdout hljs language-plaintext" data-testcase-execution-id="637">グレゴール・寒サ
+</code></pre>
+ <h4>標準エラー出力</h4>
+ <pre><code class="js-testcase-execution-stderr hljs language-plaintext" data-testcase-execution-id="637">
+</code></pre>
+ </div>
+ <script type="module" src="../../../../assets/loading.js"></script>
+ </main>
+ <footer class="container text-center mt-5 mb-4">
+ Albatross.PHP - PHPerKaigi 2024
+ </footer>
+ </body>
+</html>