首页 > 后端开发 > Python教程 > 代码的出现 &#- 天爪装置

代码的出现 &#- 天爪装置

Barbara Streisand
发布: 2024-12-30 06:30:10
原创
1053 人浏览过

Advent of Code

第 13 天:爪子装置(数学、数学和更多数学)。

解决方案链接

今天的挑战是用 Python 完成的,但有所改变。做出此选择是为了:
a) 测试我的 python / 了解更多 python
b) 今天看起来像是一个非常沉重的数学难题,所以觉得 Python 会是完美的,我没有错 - 它快如闪电。

欢迎来到今天的难题,数学课悲伤的脸,我不知道如何解决这个问题(第二部分),一开始我暴力破解,循环(最多 100 次)直到找到正确的“路线”。

正如预期的那样,第 1 部分效果很好。然而,对于第二部分,我知道情况不会如此,所以回去寻找数学方法,我有一种预感,这一定是团队推动我们前进的方向。谷歌搜索后,经过大量搜索,我发现了克莱默规则(老实说,我第一次听说它)。

任务是:

按下按钮计算获得奖品的最低成本。

对于第 1 部分,确定是否可以通过按下按钮到达目标,以及如果按下 100 次即可成功赢得的奖品的最高数量是多少,以及这样做的成本。

对于第 2 部分,通过处理大坐标偏移来优化性能,本质上消除了 100 次按钮按下限制,并将奖品位置推入深渊。

解决方案

克莱默法则似乎是解决这个问题的绝佳方法,因为它可以让您有效地求解描述如何移动爪子以在每台机器中获得奖品的线性方程。让我们来分析一下克莱默规则适用的原因和方式:

问题分解

对于每台抓娃娃机,我们有两个方程:

方程 1(来自按钮 A):
a1 * A b1 * B = c1

方程 2(来自按钮 B):
a2 * A b2 * B = c2

其中a1b1是按钮A沿X轴和Y轴的移动,A是按下A按钮的次数,c1是目标位置在 X 轴上(奖品位置)。

其中a2和b2是按钮B沿X轴和Y轴的移动,B是按下B按钮的次数,c2是Y轴上的目标位置(奖品位置)。

对于每台夹娃娃机,我们想要求解按下按钮 A 和 B 的次数(需要按下按钮 A 和 B 的次数),从而将夹娃娃与坐标 (c1, c2) 处的奖品对齐在 X 和 Y 轴上。

为什么克莱默规则有用

克莱默法则专门用于求解线性方程组。线性方程组只是一组两个或多个共享公共变量的方程,目标是找到同时满足所有方程的变量的值。

简单来说:

想象你有多个方程来描述事物之间的关系。

每个方程都使用相同的变量(例如 x 和 y),并且您试图找到这些变量的值,使所有方程同时成立。

在这种情况下,每台机器的按钮配置可以表示为 2x2 线性方程组,其中我们求解两个未知数,A(按下按钮 A)和 B(按下按钮 B)。

开发人员如何知道将来使用克莱默规则?

方程组:开发人员要做的第一件事就是确定问题需要求解线性方程组。

模式识别:开发人员认识到这是一个 2x2 系统,并且克莱默规则是解决该问题的直接方法。

*行列式和矩阵:*他们记得行列式可以用来求解线性方程中的未知数,如果行列式为零,则表明存在问题(无解或无限解)。

简单明了:克莱默法则提供了一种简单、直接的方法来查找 A 和 B 的值,而不需要迭代方法或复杂的代数。

示例:第一台夹娃娃机

按钮动作及奖品位置如下:

Button A moves the claw X+94, Y+34.
Button B moves the claw X+22, Y+67.
Prize location is at X=8400, Y=5400.
登录后复制
登录后复制

我们有方程组:

94 * A + 22 * B = 8400   (Equation for X-axis)
34 * A + 67 * B = 5400   (Equation for Y-axis)
登录后复制

第 1 步:计算行列式
主要决定因素 D:
行列式 D 使用以下公式计算:

D = a1 * b2 - a2 * b1
登录后复制

替换值:

D = (94 * 67) - (34 * 22)
D = 6298 - 748
D = 5550
登录后复制

A、D_x 的行列式:
接下来,我们使用以下公式计算行列式 D_x:

D_x = c1 * b2 - c2 * b1
登录后复制

替换值:

D_x = (8400 * 67) - (5400 * 22)
D_x = 562800 - 118800
D_x = 444000
登录后复制

B、D_y 的行列式:
现在,使用以下公式计算行列式 D_y:

D_y = a1 * c2 - a2 * c1
登录后复制

替换值:

D_y = (94 * 5400) - (34 * 8400)
D_y = 507600 - 285600
D_y = 222000
登录后复制

第 2 步:求解 A 和 B
使用克莱默法则,我们现在解决 A 和 B:

A = D_x / D
B = D_y / D
登录后复制

求解 A:

A = 444000 / 5550
A = 80
登录后复制

求解 B:

B = 222000 / 5550
B = 40
登录后复制

第 3 步:检查有效整数
A和B都是整数,也就是说这个夹娃娃机是有可能中奖的。

第 4 步:计算总成本
按下按钮 A 的成本是 3 个令牌,按下按钮 B 的成本是 1 个令牌。所以,赢得奖品的总成本是:

Button A moves the claw X+94, Y+34.
Button B moves the claw X+22, Y+67.
Prize location is at X=8400, Y=5400.
登录后复制
登录后复制

第 2 部分 - 使用相同的逻辑,唯一的区别是我们向奖品坐标的 X 轴和 Y 轴添加 10^13 偏移量。

我知道这很多,并且相信我也花了很多时间来理解/理解它。很高兴能与您聊天,您可以通过 Twitter 联系我。

以上是代码的出现 &#- 天爪装置的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板