python解决一元一次方程组

运用第三方库

python 复制代码
# 有多个未知数,且包含
'4+3x=8''-5+12y=0''6a-5+1=2-2a''-4b=10'
test = '-4b=10'
# 解决首个为负号的问题
if test[0]=="-":
    last_fuhao = test[0]
    test = test[1:]
else:
    last_fuhao = "+" # 因为要把符号也搬进去,所以有个初始的符号位
# print("第一个符号",last_fuhao)
# print("处理后的方程",test)
# 第一步:将= 替换成减号,并添加()
left,right = test.split("=")
# 把右边的处理掉,因为移位必须换符号,因此把 + 换 -,- 换 +
true_right = ""
for r in range(len(right)):
    if  right[r] =="+":
        true_right+="-"
    elif right[r] =="-":
        true_right+="+"
    else:
        true_right +=right[r]
# print(true_right)
sum_result = left+"-"+f"{true_right}"+"+" # 在程序中是已符号结尾
print("处理后的方程:",sum_result[:-1])
# 遍历:找出含有未知数的东西,添加到列表中去
# 检测数字是否为阿拉伯数字,如果是,就往后找看看有没有包含字母,有则截取到列表中去,
# 从符号开始检索起
zimu_list = []
num_str = ""
# print(ord("+"))  # 97-122  # 48-57  # 42-47

temp_str = ""

for i in range(len(sum_result)):
    # print(sum_result[i])
    if 42 <= ord(sum_result[i]) <= 47:  # 符号前停止,并判断是否有未知数
        # 未知数都在最后一个,所以直接找最后一个是否是未知数
        # print(temp_str[-1])
        if 97<= ord(temp_str[-1]) <= 122:
            zimu_list.append(last_fuhao+temp_str)
        else:
            num_str+=(last_fuhao+temp_str)
        last_fuhao = sum_result[i]
        temp_str = ""
    # 将已知数 或者 未知数拼接起来
    elif sum_result[i] in "0123456789":
        temp_str+=sum_result[i]
    elif 97<= ord(sum_result[i]) <= 122:
        temp_str+=sum_result[i]
# print("纯数字",(num_str))
beizhuchu = eval(num_str) # 被除数
# print(zimu_list)
chushu = ""
for i in zimu_list:
    # print(i[0:-1])
    chushu+=i[0:-1]
chushu = eval(chushu)
print("未知数的结果:",(beizhuchu / chushu)*-1) # 因为未知数没有移位,所以最后要乘以 -1 ,取相反数
相关推荐
夜思红尘1 小时前
算法--双指针
python·算法·剪枝
人工智能训练1 小时前
OpenEnler等Linux系统中安装git工具的方法
linux·运维·服务器·git·vscode·python·ubuntu
散峰而望2 小时前
【算法竞赛】C++函数详解:从定义、调用到高级用法
c语言·开发语言·数据结构·c++·算法·github
冷凝雨2 小时前
复数乘法(C & Simulink)
c语言·开发语言·信号处理·simulink·dsp
CoderCodingNo2 小时前
【GESP】C++五级真题(贪心思想考点) luogu-B4071 [GESP202412 五级] 武器强化
开发语言·c++·算法
0和1的舞者2 小时前
Spring AOP详解(一)
java·开发语言·前端·spring·aop·面向切面
MoonBit月兔2 小时前
年终 Meetup:走进腾讯|AI 原生编程与 Code Agent 实战交流会
大数据·开发语言·人工智能·腾讯云·moonbit
智航GIS2 小时前
8.2 面向对象
开发语言·python
小小星球之旅2 小时前
CompletableFuture学习
java·开发语言·学习
蹦蹦跳跳真可爱5893 小时前
Python----大模型(GPT-2模型训练加速,训练策略)
人工智能·pytorch·python·gpt·embedding