
代码日历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 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);
在示例输入上运行它会产生正确的答案。
在我的难题输入上呢?
一款非常包包、衣服、鞋子类网站,页面干净清洁、一目了然,mttshop打造精致、简单、易用、免费的商城。 系统要求:IIS5.1以后,必须安装.net 3.5 安装步骤: 1、下载完成后,直接解压文件mttshop.rar 2、附加数据库:解压后的可以找一个叫db的文件夹,解压后直接附加就可以,支持SQL 2000、2005、2008 3、配置web.config文件,找到key=&qu
...
好吧,它在一秒钟内就完成了,并在数千个答案中生成了一个答案。
正确吗?
...
是的!
太棒了!
我不需要计算机科学知识就能将我的蛮力算法重构为可以解决第二部分的东西。
不过,我还是很高兴看到这个结果!
第2部分
yyyuuupp。正是我所担心的。
1万亿?哎呀!
就像昨天的第二部分一样,我感到很沮丧。
太糟糕了。在连续10天获得2星后,我连续3天获得1星。
公平地说,这通常是我每年获得0星或1星的地方。至少我得到了1星!
开始第14天。









