吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 2236|回复: 13
收起左侧

[Python 转载] PYTHON之化简求解一元一次方程

[复制链接]
c03xp 发表于 2020-9-14 16:59
最近学习PLY,写了一个简单的解方程程序,暂时只能解一元一次方程,只能用整数
[Python] 纯文本查看 复制代码
tokens = (
    'NUMBER','UKN','PARENVAR',
    'PLUS','MINUS','EQUALS',
    'LPAREN','RPAREN',
    )
# Tokens
t_PLUS    = r'\+'
t_MINUS   = r'-'
t_EQUALS  = r'='
t_LPAREN  = r'\('
t_RPAREN  = r'\)'

def t_PARENVAR(t):
    r'\)x'
    return t

def t_UKN(t):
    r'x|[2-9]x|[1-9][0-9]+x'
    if(t.value == 'x'):
        t.value = (1,0)
    else:
        t.value = (int(t.value[:-1]),0)
    return t

def t_NUMBER(t):
    r'\d+'
    t.value = (0, int(t.value))
    return t
    
# Ignored characters
t_ignore = " \t"   
    
    
def t_error(t):
    print("Illegal character '%s'" % t.value[0])
    t.lexer.skip(1)
    
    
# Build the lexer
import ply.lex as lex
lexer = lex.lex(debug=False)

# Parsing rules
precedence = (
    ('left','PLUS','MINUS'),
    ('right','UMINUS'),
    )

def p_statement_expr(t):
    'statement : expression EQUALS expression'
    final = (t[1][0] - t[3][0],t[1][1] - t[3][1])
    if(final[0] == 0):
        if(final[1] == 0):
            print("infinite solutions")
        else:
            print("no solution")
    else:
        print("simplest : %s"% (str(final[0]) + 'x' + '+' + str(final[1]) + ' = 0'))
        print("x = %.3f"%( -final[1]/final[0]))

def p_expression_binop(t):
    '''expression : expression PLUS expression
                  | expression MINUS expression'''
    if t[2] == '+'  : t[0] = (t[1][0]+t[3][0],t[1][1] + t[3][1])
    elif t[2] == '-': t[0] = (t[1][0]-t[3][0],t[1][1] - t[3][1])


def p_expression_uminus(t):
    'expression : MINUS expression %prec UMINUS'
    t[0] =(-t[2][0], -t[2][1])
       
def p_expression_mulgroupx(t):
    'expression : NUMBER LPAREN expression PARENVAR'
    if(t[3][0] != 0):
        print("warning : only linear equation supported!")    
    t[0] = (t[1][1]*t[3][1],0)    
       
def p_expression_groupx(t):
    'expression : LPAREN expression PARENVAR'
    if(t[2][0] != 0):
        print("warning : only linear equation supported!")
    t[0] = (t[2][1],0)   

def p_expression_group(t):
    'expression : LPAREN expression RPAREN'
    t[0] = t[2]
    
def p_expression_mulgroup(t):
    'expression : NUMBER LPAREN expression RPAREN'
    t[0] = (t[3][0]*t[1][1],t[3][1]*t[1][1])  

def p_expression_number(t):
    'expression : NUMBER'
    t[0] = (0,t[1][1])

def p_expression_ukn(t):
    'expression : UKN'
    t[0] = (t[1][0],0)
    
def p_error(t):
    print("Syntax error" ,t.value)

import ply.yacc as yacc
parser = yacc.yacc(debug=False)

while True:
    try:
        s = input('calc > ')
    except EOFError:
        break
    parser.parse(s)
QQ图片20200914165848.png

免费评分

参与人数 3吾爱币 +8 热心值 +3 收起 理由
Alex27933 + 1 用心讨论,共获提升!
苏紫方璇 + 7 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
爱的人 + 1 + 1 我很赞同!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

fanvalen 发表于 2020-9-14 17:09
啥 解个方程还要1块钱一次
 楼主| c03xp 发表于 2020-9-14 17:12
netspirit 发表于 2020-9-14 17:16
fanvalen 发表于 2020-9-14 17:09
啥 解个方程还要1块钱一次

直接把楼主的代码偷走就不用钱了~~~~~
qianbian 发表于 2020-9-14 17:25
fanvalen 发表于 2020-9-14 17:09
啥 解个方程还要1块钱一次

还有更黑心的,2元一次!
youkan_pj 发表于 2020-9-14 17:44
fanvalen 发表于 2020-9-14 17:09
啥 解个方程还要1块钱一次

懵逼的我看了半天才理解过来,一元一次方程
fanvalen 发表于 2020-9-14 18:04
youkan_pj 发表于 2020-9-14 17:44
懵逼的我看了半天才理解过来,一元一次方程

一元一次
哈哈哈
爱的人 发表于 2020-9-14 19:14
写的太乱了!导包都是第一行的  不要到处导包!就是写的有点乱
爱的人 发表于 2020-9-14 19:15
最好就加入if name  == main
国际豆哥 发表于 2020-9-14 21:07
我寻思着一元一次方程可能蛮简单的
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-26 01:48

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表