【10月更文挑战第15天】「Mac上学Python 26」小学奥数篇12 - 图形变换与坐标计算

本文涉及的产品
实时计算 Flink 版,5000CU*H 3个月
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
实时数仓Hologres,5000CU*H 100GB 3个月
简介: 本篇将通过 Python 和 Cangjie 双语实现图形变换与坐标计算。这个题目帮助学生理解平面几何中的旋转、平移和对称变换,并学会用编程实现坐标变化。

本篇将通过 PythonCangjie 双语实现图形变换与坐标计算。这个题目帮助学生理解平面几何中的旋转、平移和对称变换,并学会用编程实现坐标变化。

geometricgeometric.png


关键词
  • 小学奥数
  • Python + Cangjie
  • 图形变换
  • 坐标计算

一、题目描述

编写一个程序,模拟以下三种图形变换:

  1. 平移变换:将点 (x, y) 平移 dxdy 个单位。
  2. 旋转变换:将点 (x, y) 绕原点顺时针旋转 θ 度。
  3. 对称变换:计算点 (x, y) 关于 x轴y轴 的对称点。

输入格式

  • 平移变换:输入 x, y, dx, dy
  • 旋转变换:输入 x, y, θ(角度)。
  • 对称变换:输入 x, y

输出格式:输出变换后的坐标,保留两位小数。


解题思路
  1. 平移变换公式x' = x + dxy' = y + dy
  2. 旋转变换公式
    • x' = x * cos(θ) + y * sin(θ)
    • y' = -x * sin(θ) + y * cos(θ)
  3. 对称变换
    • 关于 x 轴对称:y' = -y
    • 关于 y 轴对称:x' = -x

二、Python 实现

import math

# 平移变换
def translate(x, y, dx, dy):
    return x + dx, y + dy

# 旋转变换
def rotate(x, y, theta):
    rad = math.radians(theta)
    x_new = x * math.cos(rad) + y * math.sin(rad)
    y_new = -x * math.sin(rad) + y * math.cos(rad)
    return round(x_new, 2), round(y_new, 2)

# 对称变换
def reflect(x, y):
    return -x, -y

# 输入测试
x, y = map(float, input("请输入点的坐标 (x, y): ").split())
dx, dy = map(float, input("请输入平移量 (dx, dy): ").split())
theta = float(input("请输入旋转角度 θ: "))

# 输出结果
print("平移后的坐标:", translate(x, y, dx, dy))
print("旋转后的坐标:", rotate(x, y, theta))
print("关于原点的对称点:", reflect(x, y))

三、Cangjie 实现

package cjcDemo

import std.convert.*    // 导入数据转换模块
import std.console.*    // 导入控制台输入输出模块
import std.format.*     // 导入格式化模块
import std.math.*       // 导入数学函数模块

// 定义函数接收并转换用户输入为 Float64
func inputFloat(info: String): Float64 {
    print(info)  // 输出提示信息
    let number: Float64 = Float64.parse(Console.stdIn.readln().getOrThrow())  // 读取并转换输入
    return number
}

func inputFloat2(info: String): (Float64, Float64) {
    print(info)  // 输出提示信息
    var arr: Array<String> = Console.stdIn.readln().getOrThrow().split(' ')
    return (Float64.parse(arr[0]), Float64.parse(arr[1]))
}

// 自定义角度转弧度的函数
func toRadians(degrees: Float64): Float64 {
    let pi = 3.1415
    return degrees * pi / 180.0
}

// 平移变换
func translate(x: Float64, y: Float64, dx: Float64, dy: Float64): (Float64, Float64) {
    return (x + dx, y + dy)
}

// 旋转变换
func rotate(x: Float64, y: Float64, theta: Float64): (Float64, Float64) {
    let rad = toRadians(theta)  // 调用自定义的 toRadians 函数
    let x_new = x * cos(rad) + y * sin(rad)
    let y_new = -x * sin(rad) + y * cos(rad)
    return (x_new, y_new)
}

// 对称变换
func reflect(x: Float64, y: Float64): (Float64, Float64) {
    return (-x, -y)
}

// 主程序
main(): Int64 {
    let (x, y) = inputFloat2("请输入点的坐标 (x, y): ")
    let (dx, dy) = inputFloat2("请输入平移量 (dx, dy): ")
    let theta = inputFloat("请输入旋转角度 θ: ")

    let translated = translate(x, y, dx, dy)
    let rotated = rotate(x, y, theta)
    let reflected = reflect(x, y)

    println("平移后的坐标: (${translated[0].format("0.1")}, ${translated[1].format("0.1")})")
    println("旋转后的坐标: (${rotated[0].format("0.1")}, ${rotated[1].format("0.1")})")
    println("关于原点的对称点: (${reflected[0].format("0.1")}, ${reflected[1].format("0.1")})")

    return 0
}

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

以下代码使用 Python 生成一个图形,展示了图形的平移、旋转和对称变换。本部分为进阶内容,当前阶段不要求理解

from PIL import Image, ImageDraw, ImageFont

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

# 绘制平移、旋转和对称变换的结果
draw.text((10, 10), "平移后的坐标: (3.0, 4.0)", fill="black", font=font)
draw.text((10, 50), "旋转后的坐标: (1.0, -1.0)", fill="black", font=font)
draw.text((10, 90), "关于原点的对称点: (-1.0, -1.0)", fill="black", font=font)

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

生成的图像如下:
geometric_transformations.pnggeometric_transformations.png


五、示例执行

示例 1

输入:
x, y = 1, 1
dx, dy = 2, 3
θ = 90
输出:
平移后的坐标: (3.0, 4.0)
旋转后的坐标: (1.0, -1.0)
关于原点的对称点: (-1.0, -1.0)

六、小结

通过这道图形变换与坐标计算的题目,学生学习了平移、旋转和对称的变换规则,并掌握了如何用编程实现这些几何计算。


上一篇: 「Mac上学Python 25」小学奥数篇11 - 最大公约数与最小公倍数

下一篇: 「Mac上学Python 27」小学奥数篇13 - 动态规划入门


目录
相关文章
|
15天前
|
机器学习/深度学习 算法 编译器
Python程序到计算图一键转化,详解清华开源深度学习编译器MagPy
【10月更文挑战第26天】MagPy是一款由清华大学研发的开源深度学习编译器,可将Python程序一键转化为计算图,简化模型构建和优化过程。它支持多种深度学习框架,具备自动化、灵活性、优化性能好和易于扩展等特点,适用于模型构建、迁移、部署及教学研究。尽管MagPy具有诸多优势,但在算子支持、优化策略等方面仍面临挑战。
41 3
|
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
|
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编程中几种核心设计模式的应用实例与优势,不涉及具体代码示例,而是聚焦于每种模式背后的设计理念、适用场景及其如何促进代码的可维护性和扩展性。通过理解这些设计模式,开发者可以更加高效地构建软件系统,实现代码复用,提升项目质量。 ####
|
4天前
|
机器学习/深度学习 存储 算法
探索Python编程:从基础到高级应用
【10月更文挑战第38天】本文旨在引导读者从Python的基础知识出发,逐渐深入到高级编程概念。通过简明的语言和实际代码示例,我们将一起探索这门语言的魅力和潜力,理解它如何帮助解决现实问题,并启发我们思考编程在现代社会中的作用和意义。