【10月更文挑战第11天】「Mac上学Python 21」小学奥数篇7 - 二元一次方程组求解

本文涉及的产品
实时计算 Flink 版,5000CU*H 3个月
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
实时数仓Hologres,5000CU*H 100GB 3个月
简介: 本篇将通过 Python 和 Cangjie 双语讲解如何求解二元一次方程组。通过这道题,学生将学会如何使用代数方法和编程逻辑求解方程组中的未知数。

本篇将通过 PythonCangjie 双语讲解如何求解二元一次方程组。通过这道题,学生将学会如何使用代数方法编程逻辑求解方程组中的未知数。

equationequation.png


关键词
  • 小学奥数
  • Python + Cangjie
  • 二元一次方程组

一、题目描述

编写一个程序求解二元一次方程组:

  • 方程1a1 * x + b1 * y = c1
  • 方程2a2 * x + b2 * y = c2

用户需要输入系数 a1, b1, c1, a2, b2, c2,程序将输出方程组的解 xy。如果方程组无解或有无数解,程序应给出提示。


二、Python 实现

# 接收用户输入的系数
a1 = float(input("请输入 a1: "))
b1 = float(input("请输入 b1: "))
c1 = float(input("请输入 c1: "))
a2 = float(input("请输入 a2: "))
b2 = float(input("请输入 b2: "))
c2 = float(input("请输入 c2: "))

# 计算行列式 Δ, Δx, Δy
delta = a1 * b2 - a2 * b1
delta_x = c1 * b2 - c2 * b1
delta_y = a1 * c2 - a2 * c1

# 判断并求解
if delta == 0:
    if delta_x == 0 and delta_y == 0:
        print("无数解")
    else:
        print("无解")
else:
    x = delta_x / delta
    y = delta_y / delta
    print(f"x = {x:.2f}, y = {y:.2f}")

三、Cangjie 实现

package cjcDemo

import std.convert.*
import std.console.*
import std.format.*

func inputFloat(info: String): Float64 {
    print(info)
    let number: Float64 = Float64.parse(Console.stdIn.readln().getOrThrow())
    return number
}

main(): Int64 {
    let a1 = inputFloat("请输入 a1: ")
    let b1 = inputFloat("请输入 b1: ")
    let c1 = inputFloat("请输入 c1: ")
    let a2 = inputFloat("请输入 a2: ")
    let b2 = inputFloat("请输入 b2: ")
    let c2 = inputFloat("请输入 c2: ")

    let delta = a1 * b2 - a2 * b1
    let delta_x = c1 * b2 - c2 * b1
    let delta_y = a1 * c2 - a2 * c1

    if (delta == 0.0) {
        if (delta_x == 0.0 && delta_y == 0.0) {
            println("无数解")
        } else {
            println("无解")
        }
    } else {
        let x = delta_x / delta
        let y = delta_y / delta
        println("x = ${x.format("0.2")}, y = ${y.format("0.2")}")
    }

    return 0
}

代码详解
  1. 用户输入:接收六个系数,并将其转换为浮点数。
  2. 行列式计算:计算 Δ 判断方程组是否有唯一解。
  3. 特殊情况判断:根据 Δ 和常数项的比例关系判断无解或无数解。

示例执行

示例 1

输入:
a1 = 2, b1 = 3, c1 = 5
a2 = 1, b2 = -1, c2 = -1
输出:
x = 0.40, y = 1.40

示例 2

输入:
a1 = 1, b1 = 2, c1 = 3
a2 = 2, b2 = 4, c2 = 6
输出:
无数解

示例 3

输入:
a1 = 1, b1 = 2, c1 = 3
a2 = 2, b2 = 4, c2 = 7
输出:
无解

四、图形展示(扩展部分)

以下代码使用 Python 生成了一个图形,展示了二元一次方程组的解法。本部分是进阶扩展内容,当前阶段不要求理解

from PIL import Image, ImageDraw, ImageFont

# 创建画布
img = Image.new('RGB', (600, 300), color='white')
draw = ImageDraw.Draw(img)
font = ImageFont.load_default()

# 绘制方程与解
draw.text((10, 10), "方程1: 2x + 3y = 5", fill="black", font=font)
draw.text((10, 40), "方程2: x - y = -1", fill="black", font=font)
draw.text((10, 70), "解: x = 0.40, y = 1.40", fill="blue", font=font)

# 保存图像
img_path = "system_equation_solution.png"
img.save(img_path)
print(f"图形已保存为 {img_path}")

生成的图形如下:
system_equation_solution.pngsystem_equation_solution.png


五、小结

通过这道二元一次方程组的求解题,学生可以掌握如何使用代数方法克拉默法则解决数学问题,并学会判断方程组是否有解。


上一篇: 「Mac上学Python 20」小学奥数篇6 - 一元一次方程求解

下一篇: 「Mac上学Python 22」小学奥数篇8 - 排列组合计算


目录
相关文章
|
4天前
|
编解码 Java 程序员
写代码还有专业的编程显示器?
写代码已经十个年头了, 一直都是习惯直接用一台Mac电脑写代码 偶尔接一个显示器, 但是可能因为公司配的显示器不怎么样, 还要接转接头 搞得桌面杂乱无章,分辨率也低,感觉屏幕还是Mac自带的看着舒服
|
6天前
|
存储 缓存 关系型数据库
MySQL事务日志-Redo Log工作原理分析
事务的隔离性和原子性分别通过锁和事务日志实现,而持久性则依赖于事务日志中的`Redo Log`。在MySQL中,`Redo Log`确保已提交事务的数据能持久保存,即使系统崩溃也能通过重做日志恢复数据。其工作原理是记录数据在内存中的更改,待事务提交时写入磁盘。此外,`Redo Log`采用简单的物理日志格式和高效的顺序IO,确保快速提交。通过不同的落盘策略,可在性能和安全性之间做出权衡。
1551 8
|
1月前
|
弹性计算 人工智能 架构师
阿里云携手Altair共拓云上工业仿真新机遇
2024年9月12日,「2024 Altair 技术大会杭州站」成功召开,阿里云弹性计算产品运营与生态负责人何川,与Altair中国技术总监赵阳在会上联合发布了最新的“云上CAE一体机”。
阿里云携手Altair共拓云上工业仿真新机遇
|
10天前
|
人工智能 Rust Java
10月更文挑战赛火热启动,坚持热爱坚持创作!
开发者社区10月更文挑战,寻找热爱技术内容创作的你,欢迎来创作!
660 25
|
6天前
|
存储 SQL 关系型数据库
彻底搞懂InnoDB的MVCC多版本并发控制
本文详细介绍了InnoDB存储引擎中的两种并发控制方法:MVCC(多版本并发控制)和LBCC(基于锁的并发控制)。MVCC通过记录版本信息和使用快照读取机制,实现了高并发下的读写操作,而LBCC则通过加锁机制控制并发访问。文章深入探讨了MVCC的工作原理,包括插入、删除、修改流程及查询过程中的快照读取机制。通过多个案例演示了不同隔离级别下MVCC的具体表现,并解释了事务ID的分配和管理方式。最后,对比了四种隔离级别的性能特点,帮助读者理解如何根据具体需求选择合适的隔离级别以优化数据库性能。
213 3
|
1天前
|
Python
【10月更文挑战第10天】「Mac上学Python 19」小学奥数篇5 - 圆和矩形的面积计算
本篇将通过 Python 和 Cangjie 双语解决简单的几何问题:计算圆的面积和矩形的面积。通过这道题,学生将掌握如何使用公式解决几何问题,并学会用编程实现数学公式。
102 59
|
13天前
|
Linux 虚拟化 开发者
一键将CentOs的yum源更换为国内阿里yum源
一键将CentOs的yum源更换为国内阿里yum源
675 5
|
2天前
|
Java 开发者
【编程进阶知识】《Java 文件复制魔法:FileReader/FileWriter 的奇妙之旅》
本文深入探讨了如何使用 Java 中的 FileReader 和 FileWriter 进行文件复制操作,包括按字符和字符数组复制。通过详细讲解、代码示例和流程图,帮助读者掌握这一重要技能,提升 Java 编程能力。适合初学者和进阶开发者阅读。
100 61
|
13天前
|
JSON 自然语言处理 数据管理
阿里云百炼产品月刊【2024年9月】
阿里云百炼产品月刊【2024年9月】,涵盖本月产品和功能发布、活动,应用实践等内容,帮助您快速了解阿里云百炼产品的最新动态。
阿里云百炼产品月刊【2024年9月】
|
2天前
vue3+Ts 二次封装ElementUI form表单
【10月更文挑战第8天】
107 57