結果

問題 No.337 P versus NP
ユーザー kimiyukikimiyuki
提出日時 2016-01-29 22:51:20
言語 C90
(gcc 12.3.0)
結果
AC  
実行時間 1 ms / 2,000 ms
コード長 1,297 bytes
コンパイル時間 152 ms
コンパイル使用メモリ 22,016 KB
実行使用メモリ 5,376 KB
最終ジャッジ日時 2024-09-21 18:26:34
合計ジャッジ時間 942 ms
ジャッジサーバーID
(参考情報)
judge4 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 23
権限があれば一括ダウンロードができます

ソースコード

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