[
板情報
|
カテゴリランキング
]
したらばTOP
■掲示板に戻る■
全部
1-100
最新50
|
メール
|
1-
101-
201-
301-
401-
501-
601-
701-
801-
901-
1001-
1101-
1201-
1301-
1401-
1501-
1601-
1701-
1801-
1901-
2001-
2101-
2201-
2301-
2401-
2501-
2601-
2701-
2801-
2901-
3001-
3101-
3201-
3301-
3401-
3501-
3601-
3701-
3801-
3901-
4001-
4101-
4201-
4301-
4401-
4501-
4601-
4701-
4801-
4901-
5001-
5101-
5201-
5301-
5401-
この機能を使うにはJavaScriptを有効にしてください
|
管理人の独り言(プログラミング関連)
478
:
◆rCEzuNnL0g
:2008/09/24(水) 20:36:04
BrainCrashを実装してみた。あんまり代わってない。
-----
BrainCrash
http://cfs.maxn.jp/neta/BrainCrash.php
-----
#include <iostream>
#include <string>
int main(int argc, char **argv){
static unsigned char test[10000];
register unsigned int ptr = 0;
memset(test, 0, sizeof(test));
strcpy((char *)test, "Hello, world!");
std::wstring wstr;
std::getline(std::wcin, wstr);
for(unsigned int c = 0, size = wstr.length(); c < size; c++){
switch(wstr[c]){
case L'>': ptr++; break;
case L'<': if(ptr) ptr--; break;
case L'+': test[ptr]++; break;
case L'-': test[ptr]--; break;
case L'.': std::cout << test[ptr] << std::flush; break;
case L',': break; //TODO:
case L'[': if(!test[ptr]){while(wstr[++c] != L']');} break;
case L']': if(test[ptr]){c--; while(wstr[c--] != L'[');} break;
case L'|': test[ptr + 1] |= test[ptr]; ptr++; break;
case L'&': test[ptr + 1] &= test[ptr]; ptr++; break;
case L'~': test[ptr] = ~test[ptr];
case L'^': test[ptr + 1] ^= test[ptr]; ptr++; break;
}
}
while(test[ptr]){
std::cout << test[ptr] << std::flush;
ptr++;
}
}
新着レスの表示
名前:
E-mail
(省略可)
:
※書き込む際の注意事項は
こちら
※画像アップローダーは
こちら
(画像を表示できるのは「画像リンクのサムネイル表示」がオンの掲示板に限ります)
スマートフォン版
掲示板管理者へ連絡
無料レンタル掲示板