結果

問題 No.337 P versus NP
ユーザー kimiyukikimiyuki
提出日時 2016-01-29 22:51:20
言語 C90
(gcc 11.4.0)
結果
AC  
実行時間 1 ms / 2,000 ms
コード長 1,297 bytes
コンパイル時間 557 ms
コンパイル使用メモリ 22,008 KB
実行使用メモリ 4,348 KB
最終ジャッジ日時 2023-10-21 17:11:43
合計ジャッジ時間 1,121 ms
ジャッジサーバーID
(参考情報)
judge12 / judge9
このコードへのチャレンジ(β)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
4,348 KB
testcase_01 AC 0 ms
4,348 KB
testcase_02 AC 0 ms
4,348 KB
testcase_03 AC 0 ms
4,348 KB
testcase_04 AC 0 ms
4,348 KB
testcase_05 AC 0 ms
4,348 KB
testcase_06 AC 1 ms
4,348 KB
testcase_07 AC 1 ms
4,348 KB
testcase_08 AC 1 ms
4,348 KB
testcase_09 AC 1 ms
4,348 KB
testcase_10 AC 1 ms
4,348 KB
testcase_11 AC 1 ms
4,348 KB
testcase_12 AC 0 ms
4,348 KB
testcase_13 AC 1 ms
4,348 KB
testcase_14 AC 1 ms
4,348 KB
testcase_15 AC 0 ms
4,348 KB
testcase_16 AC 1 ms
4,348 KB
testcase_17 AC 1 ms
4,348 KB
testcase_18 AC 1 ms
4,348 KB
testcase_19 AC 1 ms
4,348 KB
testcase_20 AC 1 ms
4,348 KB
testcase_21 AC 0 ms
4,348 KB
testcase_22 AC 1 ms
4,348 KB
権限があれば一括ダウンロードができます

ソースコード

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