結果

問題 No.18 うーさー暗号
ユーザー kimiyukikimiyuki
提出日時 2016-01-22 19:37:34
言語 C90
(gcc 11.4.0)
結果
WA  
実行時間 -
コード長 1,196 bytes
コンパイル時間 986 ms
コンパイル使用メモリ 21,760 KB
実行使用メモリ 5,376 KB
最終ジャッジ日時 2024-09-21 15:01:22
合計ジャッジ時間 1,292 ms
ジャッジサーバーID
(参考情報)
judge2 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

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

ソースコード

diff #

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdint.h>
#include <assert.h>
const char *code =
">>>,----------[>+++++++++[<------>-]<<<<+[>+>+<<-]>[<+>-]>><[>-[>+>+<<-]>[<+>-"
"]+>[<[-]>-]<<>[-+++++[<+++++>-]<+>]<<-]>>++++++++[<++++++++>-]<.,----------]";
const char *pptr;
int len;
uint8_t mem[30000] = {};
uint8_t *ptr = mem;
void skip(void) {
    while (pptr < code+len) {
        switch (*(pptr++)) {
            case '[': skip(); break;
            case ']': return;
        }
    }
    assert (NULL);
}
void push(const char *back) {
    while (pptr < code+len) {
        switch (*(pptr++)) {
            case '>': ++ptr; break;
            case '<': --ptr; break;
            case '+': ++(*ptr); break;
            case '-': --(*ptr); break;
            case '.': putchar(*ptr);    break;
            case ',': *ptr = getchar(); if (*ptr == EOF) { *ptr = -1; } break;
            case '[': if (*ptr) { push(pptr);  } else { skip(); } break;
            case ']': if (*ptr) { pptr = back; } else { return; } break;
        }
    }
    assert (back == NULL);
}
int main(int argc, char *argv[]) {
    pptr = code;
    len = strlen(code);
    push(NULL);
    return 0;
}
0