「Perl」一个brainfuck 语言解释器的混乱代码版本

RT,下面代码出自没写过几行Perl 的吾辈之手,不过效果还不错——乱的一塌糊涂。

估计你已经明白为什么有“国际C语言混乱代码大赛”而没有“国际Perl语言混乱代码大赛”了=。=

如果不清楚brainfuck 的解释器是什么可以看看这篇文章,这是一个相同的C++ 版本 =w=

@_=@ARGV;exit if
@_<1;open FILE,shift;
undef$/;$_=<FILE>;s/\h|\n//g
;@_=split//;$_=$~=0;@~=();while
($_<@_){$_[$_]=~/>/&&++$~;$_
[$_]=~/</&&--$~;$_[$_]=~
/\+/&&++$~[$~];$_[$_]
=~/-/?--$~[$~]:1;
$_[$_]=~/\./
&&printf'%c',$~
[$~];$_[$_]=~/,/?$~
[$~]=getc:1;if($_[$_]
=~/\[/){$__=1;$~[$~]?++
$_&&next:1;while($__){++$_;$_
[$_]=~/\[/?++$__:1;$_[$_]=~
/\]/&&--$__;print$_[$_
],$_;}--$_;next;}if
($_[$_]=~/\]/){
$__=1;$~[$~]?(
/\/\/\/\/\/\/\/\//,
qw.enjoy brainfuck ;p.,
<<___________________________
%%%%%%%%%By iSpeller%%%%%%%%%%%
___________________________
):++$_&&next;while($__){--
$_;$_[$_]=~/\]/&&++$__;
$_[$_]=~/\[/&&--$__
;}next;}++$_;}


下面的测试代码出自ArchWiki 的Arch is the best 项目,用于输出"Arch is the best!"

++>++++++>+++++<+[>[->+<]<->++++++++++<]>>.<[-]>[-<++>]
<----------------.---------------.+++++.<+++[-<++++++++++>]<.
>>+.++++++++++.<<.>>+.------------.---.<<.>>---.
+++.++++++++++++++.+.<<+.[-]++++++++++.

Perl 是唯一的一门在RSA 加密前后看起来一样的语言。
-- Keith Bostic



我可以回答这个问题。以下是一个Rust实现的Brainfuck解释器代码示例: ```rust use std::io::{self, Read}; const MEMORY_SIZE: usize = 30000; struct Interpreter { memory: [u8; MEMORY_SIZE], pointer: usize, code: Vec<char>, code_pointer: usize, } impl Interpreter { fn new(code: Vec<char>) -> Interpreter { Interpreter { memory: [; MEMORY_SIZE], pointer: , code, code_pointer: , } } fn run(&mut self) { while self.code_pointer < self.code.len() { match self.code[self.code_pointer] { '>' => self.pointer += 1, '<' => self.pointer -= 1, '+' => self.memory[self.pointer] += 1, '-' => self.memory[self.pointer] -= 1, '.' => print!("{}", self.memory[self.pointer] as char), ',' => { let mut buffer = []; io::stdin().read_exact(&mut buffer).unwrap(); self.memory[self.pointer] = buffer[]; } '[' => { if self.memory[self.pointer] == { let mut count = 1; while count > { self.code_pointer += 1; match self.code[self.code_pointer] { '[' => count += 1, ']' => count -= 1, _ => (), } } } } ']' => { if self.memory[self.pointer] != { let mut count = 1; while count > { self.code_pointer -= 1; match self.code[self.code_pointer] { '[' => count -= 1, ']' => count += 1, _ => (), } } } } _ => (), } self.code_pointer += 1; } } } fn main() { let code = String::from("++++++++[>++++[>++>+++>+++>+<<<<-]>+>+>->>+[<]<-]>>.>---.+++++++..+++.>>.<-.<.+++.------.--------.>>+.>++.").chars().collect(); let mut interpreter = Interpreter::new(code); interpreter.run(); } ``` 希望这个代码示例能够帮助你!
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值