Brainfuck解析器(Python)

本文介绍了一种使用Python实现Brainfuck代码的解析和模拟过程。通过定义一系列函数来处理Brainfuck的基本指令,如增加或减少指针所指向的内存单元的值、移动指针位置、循环控制等,实现了Brainfuck程序的解释执行,并打印了输出结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

global cs
global ip

global ss
#global sp

global ds
global bp

global tab
global out

cs='++++++++++[>+++++++>++++++++++>+++>+<<<<-]>++.>+.+++++++..+++.>++.<<+++++++++++++++.>.+++.------.--------.>+.>.'
ip = 0

ss = []
#sp = 0

ds = []
bp = 0

tab = 0
out = []

def tab_():
    i = tab
    stab = ''
    while i > 0:
        stab += '\t'
        i -= 1
    return stab

def push(var):
    global ss
    ss.append(var)

def pop():
    global ss
    return ss.pop()

def op_inc_val():
    global ip
    count = 0
    while True:
        op = cs[ip]            
        ip = ip + 1
        if op == '+':
            count = count + 1
        else:
            break
    l = len(ds)
    if l <= bp:
        ds.append(0)
    old = ds[bp]
    old += count
    ds[bp] = old
    print tab_()+'ds[%d] += %d                  (%d)'%(bp, count, old)

def op_dec_val():
    global ip    
    count = 0
    while True:
        op = cs[ip]            
        ip = ip + 1
        if op == '-':
            count = count + 1
        else:
            break
    old = ds[bp]
    old -= count
    ds[bp] = old
    print tab_()+'ds[%d] -= %d                  (%d)'%(bp, count, old)

def op_inc_dp():
    global bp
    bp = bp + 1

def op_dec_dp():
    global bp
    bp = bp - 1

def op_jmp_fwd():
    global tab
    global ip
    print tab_()+'while ds[%d]=%d:'%(bp, ds[bp])
    tab=tab + 1
    if ds[bp] != 0:
        curip = ip - 1
        push(curip)
    else:
        c = 1; 
        while c > 0:
            op = cs[ip]
            if op == '[':
                c += 1
            elif op == ']':
                c -= 1
            ip += 1

def op_jmp_bck():
    global tab
    global ip
    tab = tab - 1
    if ds[bp] != 0:
        ip = pop()

def op_out():
    print tab_()+'putchar(ds[%d])                  (%d)'%(bp, ds[bp])
    out.append(ds[bp])

def op_in():
    print tab_()+'getchar'

end = len(cs)
while ip < end:
    op = cs[ip]
    ip = ip + 1
    if op == '+':
        ip = ip - 1
        op_inc_val()
        ip = ip - 1
    elif op == '-':
        ip = ip - 1
        op_dec_val()
        ip = ip - 1
    elif op == '>':
        op_inc_dp()
    elif op == '<':
        op_dec_dp()
    elif op == '[':
        op_jmp_fwd()
    elif op == ']':
        op_jmp_bck()
    elif op == '.':
        op_out()
    elif op == ',':
        op_in()
    else:
        print 'invalid opcode'
        break
    
print out
str = ''
for c in out:
    str += '%c'%(c)
print str

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值