爪装置
时间:2025-02-04 15:18:51 202浏览 收藏
今日不肯埋头,明日何以抬头!每日一句努力自己的话哈哈~哈喽,今天我将给大家带来一篇《爪装置》,主要内容是讲解等等,感兴趣的朋友可以收藏或者有更好的建议在评论提出,我都会认真看的!大家一起进步,一起学习!
代码日历2024年第13天
第1部分
big gulp:每个置换?
又一个令人头疼的最短路径挑战。
所幸,给定的约束条件使问题看起来可解:最多100次按键 - 这意味着如果存在解,它就存在于10,000个排列中的一个:100 * 100 = 10,000;输入中每台机器用3行(加1行空行)表示,共4行。
我的输入有1280行。
因此,我的算法最多执行的计算次数为:
100
* 100
------
10000
*
1280
/ 4
------
320
======
3200000
320万次计算,不算太坏。蛮力法可能是第一部分的一种选择。
值得一试!尝试破解解决方案。将字符串转换为整数。首先,我需要从每台机器的输入中提取六个重要数字:
```javascript
input .split('\n') .map(block => { let [ax, ay, bx, by, px, py] = [ ...block.matchall(/\d+/g).map(el => +el[0]) ] })
我在这里写下了代码。然后在代码编辑器中运行它。
然后我进行调试和修复,直到看到我期望的结果。我的工作算法如下所示:
```javascript
input
.split('\n\n')
.map(block => [
...block.matchall(/\d+/g)
].map(el => +el[0])
)
我犯了一些愚蠢的错误,但我现在在我的控制台中看到了以下内容:
[
[ 94, 34, 22, 67, 8400, 5400 ],
[ 26, 66, 67, 21, 12748, 12176 ],
[ 17, 86, 84, 37, 7870, 6450 ],
[ 69, 23, 27, 71, 18641, 10279 ]
]
完美!准备进行10k次排列。
一些带有初始值的跟踪变量,嵌套循环计数为100,所有这些都减少了处理每台机器的过程:
let part1 = input.reduce( (total, machine) => {
let [ax, ay, bx, by, px, py] = machine
let min = Infinity
let mina = Infinity
let minb = Infinity
for (let a = 0; a < 100; a++) {
for (let b = 0; b < 100; b++) {
// ...
}
}
// ...
})
接下来,一些条件、加法和乘法:
// 在嵌套循环内 if ((a ax + b bx == px) && (a ay + b by == py)) { if (3 a + b < min) { min = 3 a + b; } }
再次,我首先在这里写下了代码。
然后我将其复制到我的代码编辑器中并运行。
我看到了预期的获胜代币数量!
我兴奋地写下了其余的算法。
清理和调试后,这是最终的工作代码:
let part1 = input.reduce( (total, machine) => {
let [AX, AY, BX, BY, PX, PY] = machine
let min = Infinity
for (let A = 0; A < 100; A++) {
for (let B = 0; B < 100; B++) {
if ((A * AX + B * BX === PX) && (A * AY + B * BY === PY)) {
min = Math.min(min, 3 * A + B);
}
}
}
return total + min;
}, 0);
在示例输入上运行它会产生正确的答案。
在我的难题输入上呢?
...
好吧,它在一秒钟内就完成了,并在数千个答案中生成了一个答案。
正确吗?
...
是的!
太棒了!
我不需要计算机科学知识就能将我的蛮力算法重构为可以解决第二部分的东西。
不过,我还是很高兴看到这个结果!
第2部分
yyyuuupp。正是我所担心的。
1万亿?哎呀!
就像昨天的第二部分一样,我感到很沮丧。
太糟糕了。在连续10天获得2星后,我连续3天获得1星。
公平地说,这通常是我每年获得0星或1星的地方。至少我得到了1星!
开始第14天。
以上就是《爪装置》的详细内容,更多关于的资料请关注golang学习网公众号!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
470 收藏
-
345 收藏
-
402 收藏
-
226 收藏
-
182 收藏
-
329 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习