「Mac玩转仓颉内测版49」小学奥数篇12 - 图形变换与坐标计算

news2024/12/23 18:24:17

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


关键词
  • 小学奥数
  • 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.png


五、示例执行

示例 1

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

六、小结

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


上一篇: 「Mac玩转仓颉内测版48」小学奥数篇11 - 最大公约数与最小公倍数
下一篇: 「Mac玩转仓颉内测版50」小学奥数篇13 - 动态规划入门

作者:SoraLuna
链接:https://www.nutpi.net/thread?topicId=398
來源:坚果派
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2257813.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

springboot系列--拦截器加载原理

一、拦截器加载原理 拦截器是在容器启动时&#xff0c;就创建并加载好&#xff0c;此时并未放入拦截器链中&#xff0c;只是放在一个拦截器集合当中&#xff0c;当一个请求进来之后&#xff0c;会通过匹配路径&#xff0c;查看是否有命中集合中的拦截器的拦截路径&#xff0c;如…

高通QCA-WiFi-10.4驱动源码解析文档:无线驱动开发的利器

高通QCA-WiFi-10.4驱动源码解析文档&#xff1a;无线驱动开发的利器 【下载地址】高通QCA-WiFi-10.4驱动源码解析文档分享 本仓库提供了一份高通最新的QCA-WiFi-10.4驱动源码解析文档&#xff0c;该文档对于无线驱动开发人员来说&#xff0c;是一份非常宝贵的帮助资料。通过这份…

数据结构与算法 五大算法

文章目录 1&#xff0c;时间复杂度与空间复杂度 2&#xff0c;插入排序 3&#xff0c;希尔排序 4&#xff0c;选择排序 1&#xff0c;单趟排序 2&#xff0c;选择排序PLUS版本 5&#xff0c;冒泡排序 6&#xff0c;快速排序 1&#xff0c;hoare版本 2&#xff0c;挖坑法 前言 …

数据链路层总结

- - 链路、物理链路&#xff1a;两节点间物理线路&#xff08;有线、无线&#xff09;&#xff0c;中间没有任何其他的交换节点 数据链路、逻辑链路&#xff1a; 链路 协议需要的硬件、软件 网络适配器(网卡)&#xff1a;包含物理层、数据链路层 网络适配器软件驱动程…

入门pytorch-Transformer

前言 虽然Transformer是2017年由Google推出&#xff0c;如果按照读论文只读近两年的思路看&#xff0c;那它无疑是过时的&#xff0c;但可惜的是&#xff0c;目前很多论文的核心依然是Transformer&#xff0c;或者由其进行改进的&#xff0c;故本文使用pytorch来搭建一下Trans…

PHP中GD库的使用

由于我要用到php的验证码 <?php session_start();// 生成验证码 $random_code substr(md5(uniqid(mt_rand(), true)), 0, 6);// 将验证码保存到 session 中 $_SESSION[captcha] $random_code;// 创建图片 $font 6; $image_width 100; $image_height 40;// 创建图像 $…

【OpenCV】图像转换

理论 傅立叶变换用于分析各种滤波器的频率特性。对于图像&#xff0c;使用 2D离散傅里叶变换&#xff08;DFT&#xff09; 查找频域。快速算法称为 快速傅立叶变换&#xff08;FFT&#xff09; 用于计算DFT。 Numpy中的傅立叶变换 首先&#xff0c;我们将看到如何使用Numpy查…

ThingsBoard规则链节点:RabbitMQ 节点详解

ThingsBoard 是一个开源的物联网平台&#xff0c;允许开发者快速构建IoT产品。它提供了设备连接、数据收集、处理和可视化等功能。为了实现高效的数据处理和消息传递&#xff0c;ThingsBoard 集成了多种消息队列服务&#xff0c;其中就包括了RabbitMQ。 RabbitMQ 是一个广泛使用…

健康管理系统(Koa+Vue3)

系统界面(源码末尾获取) 系统技术 Vue3 Koa Nodejs Html Css Js ....... 系统介绍 系统比较简单,轻轻松松面对结业课堂作业.采用的是基于nodejs开发的Koa框架作为后端,采用Vue框架作为前端,完成快速开发和界面展示. 系统获取 啊啊啊宝/KoaVue3https://gitee.com/ah-ah-b…

Muduo 网络库 入门详解

文章目录 1. 什么是 Muduo 网络库&#xff1f;2. Muduo 的核心架构2.1 EventLoop2.2 Channel2.3 Poller2.4 TimerQueue2.5 TcpServer 和 TcpConnection架构图 3. Muduo 的工作原理4. 部分组件介绍4.1 ProtobufCodec4.2 ProtobufDispatcher4.3 muduo::net::EventLoop4.4 muduo::…

Scratch游戏推荐 | 磁铁与磁场原理模型——探索科学的奥秘!

今天为大家推荐一款既有趣又富有教育意义的Scratch互动作品——《磁铁与磁场原理模型》&#xff01;由ps49student503-25制作&#xff0c;这款作品通过直观的方式展示了磁铁和磁场的相互作用&#xff0c;帮助玩家深入了解磁场的方向与强度。快来拖动磁铁&#xff0c;观察磁场如…

汽车总线协议分析-CAN总线

随着汽车工业的发展&#xff0c;汽车各系统的控制逐步向自动化和智能化转变&#xff0c;汽车电气系统变得日益复杂。许多车辆设计使用CAN、CAN-FD、LIN、FlexRay或SENT在电子控制单元(ECU)之间以及ECU与传感器&#xff0c;执行器和显示器之间进行通信。这些ECU之间的通信允许车…

十四、Pod的升级和回滚

当集群中的某个服务需要升级时,我们需要停止目前与该服务相关的所有Pod,然后下载新版本镜像并创建新的Pod。如果集群规模比较大,则这个工作变成了一个挑战,而且先全部停止然后逐步升级的方式会导致较长时间的服务不可用。Kubernetes提供了滚动升级功能来解决上述问题。 如…

Redis篇-1--入门介绍

1、Redis概述 ‌Redis&#xff08;Remote Dictionary Server&#xff09;&#xff0c;全称为远程字典服务。‌是一个开源的、使用C语言编写的、支持网络交互的、可基于内存也可持久化的Key-Value数据库。 Redis提供了多种数据类型的存储&#xff0c;来适应不同场景下的存储需…

游戏引擎学习第35天

开场介绍 今天的任务是继续改进一个虚拟的瓦片地图系统&#xff0c;使其适合处理更大的世界。我们希望这个系统能管理大范围的游戏世界&#xff0c;其中包含按需存储的小区域。昨天&#xff0c;我们介绍了“内存区域”的概念&#xff0c;用于管理持久性存储。我们计划今天继续…

Apache Echarts和POI

目录 Apache ECharts 介绍 入门 绘制一个简单的图表 Apache POI 介绍 通过POI创建Excel文件并且写入文件内容 通过POI读取Excel文件中的内容 导出Excel表格 Apache ECharts 介绍 Apache ECharts 是一款基于 Javascript 的数据可视化图表库&#xff0c;提供直观&#xf…

怎么配置点击deploy就能把jar包直接打到nexus私库上,以及怎么配置从私库下载jar包

一.怎么配置点击deploy就能把jar包直接打到nexus私库上 方式一:在pom文件配置私库地址 1.第一步&#xff0c;在pom文件配置仓库地址&#xff0c;用于 deploy 上传 releases 对应正式版的仓库 snapshots 对应快照版的仓库 如果你打的jar包是以 -SNAPSHOT 结尾的, 那么就会…

基于最新的Apache StreamPark搭建指南

一、StreamPark 的介绍 官方文档:Apache StreamPark (incubating) | Apache StreamPark (incubating) 中文文档:Apache StreamPark (incubating) | Apache StreamPark (incubating)Github地址:https://github.com/apache/incubator-streampark Apache StreamPark™ 是一个…

数字IC后端实现常见的physical only cell都有哪些?如何添加这些cell?

数字IC后端实现阶段常见功能cell有哪些&#xff1f;比如AND&#xff0c;AOI&#xff0c;NAND等。 physical cell有哪些&#xff1f;都是干什么用的&#xff1f; 数字后端零基础入门系列 | Innovus零基础LAB学习Day9 &#xff08;1&#xff09; well tap cells&#xff1a;防止…

Promise详解-1:初识Promise

最近在回顾ES6的知识&#xff0c;想整理下跟Promise相关的内容。我准备整一个Promise解读的系列&#xff0c;看看能深入到什么程度吧。由浅入深&#xff0c;先认识下Promise。 痛苦的回忆&#xff1a;回调地狱 假如现在让你维护一个“古老”的项目&#xff0c;缺少脚手架的加…