【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 - 排列组合计算


目录
相关文章
|
22天前
|
Java 索引 Python
【10月更文挑战第19天】「Mac上学Python 30」基础篇11 - 高级循环技巧与应用
本篇将介绍更深入的循环应用与优化方法,重点放在高级技巧和场景实践。我们将讲解enumerate()与zip()的妙用、迭代器与生成器、并发循环以及性能优化技巧。这些内容将帮助您编写更高效、结构更合理的代码。
59 5
|
24天前
|
数据安全/隐私保护 Python
【10月更文挑战第17天】「Mac上学Python 28」基础篇9 - 条件语句与逻辑判断
在Python中,条件语句和逻辑判断是控制程序执行流程的关键工具,帮助程序在不同条件下做出不同决策。通过本篇的学习,您将掌握单选、双分支、多选结构、单行条件表达式、条件嵌套、条件判断的类型和逻辑运算符的用法,从而更灵活地控制程序执行流程。
47 5
|
23天前
|
Python
【10月更文挑战第18天】「Mac上学Python 29」基础篇10 - 循环结构与迭代控制
在Python中,循环结构是控制程序执行的重要工具。通过学习本篇内容,您将掌握如何使用for循环和while循环来高效地处理重复任务,并了解break、continue和else的使用方式。同时,我们还会探索嵌套循环和典型应用场景中的实际应用。
38 2
|
25天前
|
存储 算法 Python
【10月更文挑战第16天】「Mac上学Python 27」小学奥数篇13 - 动态规划入门
本篇将通过 Python 和 Cangjie 双语介绍动态规划的基本概念,并解决一个经典问题:斐波那契数列。学生将学习如何使用动态规划优化递归计算,并掌握编程中的重要算法思想。
93 3
|
27天前
|
Python
【10月更文挑战第15天】「Mac上学Python 26」小学奥数篇12 - 图形变换与坐标计算
本篇将通过 Python 和 Cangjie 双语实现图形变换与坐标计算。这个题目帮助学生理解平面几何中的旋转、平移和对称变换,并学会用编程实现坐标变化。
63 1
|
28天前
|
算法 数据可视化 Python
【10月更文挑战第14天】「Mac上学Python 25」小学奥数篇11 - 最大公约数与最小公倍数
本篇将通过 Python 和 Cangjie 双语实现最大公约数(GCD)和最小公倍数(LCM)的计算。这个题目帮助学生理解如何运用数学算法,并将其与编程实现结合。
50 1
|
3天前
|
机器学习/深度学习 人工智能 TensorFlow
人工智能浪潮下的自我修养:从Python编程入门到深度学习实践
【10月更文挑战第39天】本文旨在为初学者提供一条清晰的道路,从Python基础语法的掌握到深度学习领域的探索。我们将通过简明扼要的语言和实际代码示例,引导读者逐步构建起对人工智能技术的理解和应用能力。文章不仅涵盖Python编程的基础,还将深入探讨深度学习的核心概念、工具和实战技巧,帮助读者在AI的浪潮中找到自己的位置。
|
3天前
|
机器学习/深度学习 数据挖掘 Python
Python编程入门——从零开始构建你的第一个程序
【10月更文挑战第39天】本文将带你走进Python的世界,通过简单易懂的语言和实际的代码示例,让你快速掌握Python的基础语法。无论你是编程新手还是想学习新语言的老手,这篇文章都能为你提供有价值的信息。我们将从变量、数据类型、控制结构等基本概念入手,逐步过渡到函数、模块等高级特性,最后通过一个综合示例来巩固所学知识。让我们一起开启Python编程之旅吧!
|
3天前
|
存储 Python
Python编程入门:打造你的第一个程序
【10月更文挑战第39天】在数字时代的浪潮中,掌握编程技能如同掌握了一门新时代的语言。本文将引导你步入Python编程的奇妙世界,从零基础出发,一步步构建你的第一个程序。我们将探索编程的基本概念,通过简单示例理解变量、数据类型和控制结构,最终实现一个简单的猜数字游戏。这不仅是一段代码的旅程,更是逻辑思维和问题解决能力的锻炼之旅。准备好了吗?让我们开始吧!
|
5天前
|
设计模式 算法 搜索推荐
Python编程中的设计模式:优雅解决复杂问题的钥匙####
本文将探讨Python编程中几种核心设计模式的应用实例与优势,不涉及具体代码示例,而是聚焦于每种模式背后的设计理念、适用场景及其如何促进代码的可维护性和扩展性。通过理解这些设计模式,开发者可以更加高效地构建软件系统,实现代码复用,提升项目质量。 ####