代码来临 2024 年第 4 天
第 1 部分
X 标记(数百个?)点
令我惊讶的是,到目前为止还没有像这样的文字搜索谜题。
这似乎令人畏惧,但我的策略是:
Find the index of each X in the grid For each X Check the next three letters in a straight path in each of the eight directions If the path ends up spelling XMAS Add one to a running total
在示例中检查此策略使我相信这是一种成功的方法。
现在是令人兴奋的部分:从头开始编码整个事情!
找到网格中每个 X 的索引...最终
首先,我必须将输入解析为二维字符数组:
let grid = input.split('\n').map(line => line.split(''))
我在网格谜题中经常遇到的一个障碍是考虑越界索引。
如果我从边界单元格 - 或靠近边界的单元格开始 - 并朝边缘方向走这么远,我最终会遇到越界的行或列。
我有两种策略来处理这个问题:
- 向我的条件添加检查以查找不存在的行或列
- 用足够的行和列填充网格,这样就不会出现越界的风险
对于这个挑战,我选择#2。
用 3 单元格厚边框填充网格,如下所示:
grid = grid.map(line => ['.','.','.',...line,'.','.','.']) grid = [ new Array(grid[0].length).fill('.'), new Array(grid[0].length).fill('.'), new Array(grid[0].length).fill('.'), ...grid, new Array(grid[0].length).fill('.'), new Array(grid[0].length).fill('.'), new Array(grid[0].length).fill('.') ]
示例网格现在如下所示:
................ ................ ................ ...MMMSXXMASM... ...MSAMXMSMSA... ...AMXSXMAAMM... ...MSAMASMSMX... ...XMASAMXAMM... ...XXAMMXXAMA... ...SMSMSASXSS... ...SAXAMASAAA... ...MAMMMXMMMM... ...MXMXAXMASX... ................ ................ ................
现在我准备好对填充网格中每个 X 的坐标进行编目:
let Xs = [] for (let row = 0; row <p>成功:在示例网格中找到了所有 19 个 X!</p> <h4> 从每个X向八个方向走三步 </h4> <p>所有八个相对坐标都编码为 8 元素数组:<br> </p> <pre class="brush:php;toolbar:false">let dirs = [ [-1,-1], [-1,0], [-1,1], [0,-1], [0,1], [1,-1], [1,0], [1,1] ]
现在主要算法:
For each X For each direction Create an array that starts with X Do 3 times Move one cell in this direction Add the value of that cell to the array Check whether the concatenation of all four values is "XMAS" If it is, increment a tally
在 JavaScript 中:
Xs.reduce((total, coord) => { dirs.forEach((dir) => { let [row, col] = coord; let [y, x] = dir; let word = ["X"]; for (let i = 0; i <p>它为示例输入生成正确的答案!</p> <p>当我在拼图输入上运行它时会发生什么?!!</p> <p>我得到一个数字:几千个“XMAS”</p> <p>这是正确答案吗?</p> <p>就是这样!!!</p> <p>呜呼!!!</p> <p>迫不及待地想看看第二部分有什么精彩内容......</p> <h3> 第2部分 </h3> <h4> 哦天哪。这变得有点复杂了。但可行! </h4> <p>在第 1 部分中,我一直在寻找 X。</p> <p>现在,我正在寻找</p>女士 <p>在第 1 部分中,我将字母写成一条直线来组成单词。</p> <p>现在,我正在寻找 5 单元短语的四种配置:<br> </p> <pre class="brush:php;toolbar:false">M S M M S M S S A A A A M S S S S M M M
一个 M 可以是多个 X-MAS 的一部分。
通过检查每一个M,我很可能会遇到好几次。
我需要为每场比赛构建一个字符串化坐标的 Set()。这样,我只占一个 X-MAS 实例一次。
突然——辉煌! - 主意
我不会检查每一个M。
我会检查每一个A。
我将按顺时针顺序检查对角相邻的四个单元格。
X-MAS 比赛将符合以下四种模式之一:
Find the index of each X in the grid For each X Check the next three letters in a straight path in each of the eight directions If the path ends up spelling XMAS Add one to a running total
`
唷!这比我最初的想法要简单得多。
而且我应该能够重新利用我的大部分第 1 部分代码!
复制粘贴调整
在网格中找到所有 As:
js
让 As = [];
for (let row = 0; row
for (let col = 0; col
if (网格[行][列] == "A") {
As.push([行, 列]);
}
}
}
建立要检查的相对坐标顺序:
js
让阿迪尔斯 = [
[-1, -1],
[-1, 1],
[1, 1],
[1, -1],
];
将比赛的得分相加:
js
让part2 = As.reduce((总计, 坐标) => {
让顺时针 = Adirs.map((dir) => {
让 [行,列] = 坐标;
让 [y, x] = dir;
返回网格[行y][列x];
});
if (["MSSM", "MMSS", "SMMS", "SSMM"].includes(顺时针.join(""))) {
总计;
}
返回总计;
}, 0);
它为示例输入生成正确的答案!
现在检查我的拼图输入...
确实!!!正确答案!!!
我很高兴我突然想到使用 As 而不是 Ms.
我确信,为我节省了数小时的时间来解决头痛问题。
这是另一个有趣且容易上手的谜题!
我想知道第五天会发生什么。
以上是谷神星搜索的详细内容。更多信息请关注PHP中文网其他相关文章!

引言我知道你可能会觉得奇怪,JavaScript、C 和浏览器之间到底有什么关系?它们之间看似毫无关联,但实际上,它们在现代网络开发中扮演着非常重要的角色。今天我们就来深入探讨一下这三者之间的紧密联系。通过这篇文章,你将了解到JavaScript如何在浏览器中运行,C 在浏览器引擎中的作用,以及它们如何共同推动网页的渲染和交互。JavaScript与浏览器的关系我们都知道,JavaScript是前端开发的核心语言,它直接在浏览器中运行,让网页变得生动有趣。你是否曾经想过,为什么JavaScr

Node.js擅长于高效I/O,这在很大程度上要归功于流。 流媒体汇总处理数据,避免内存过载 - 大型文件,网络任务和实时应用程序的理想。将流与打字稿的类型安全结合起来创建POWE

Python和JavaScript在性能和效率方面的差异主要体现在:1)Python作为解释型语言,运行速度较慢,但开发效率高,适合快速原型开发;2)JavaScript在浏览器中受限于单线程,但在Node.js中可利用多线程和异步I/O提升性能,两者在实际项目中各有优势。

JavaScript起源于1995年,由布兰登·艾克创造,实现语言为C语言。1.C语言为JavaScript提供了高性能和系统级编程能力。2.JavaScript的内存管理和性能优化依赖于C语言。3.C语言的跨平台特性帮助JavaScript在不同操作系统上高效运行。

JavaScript在浏览器和Node.js环境中运行,依赖JavaScript引擎解析和执行代码。1)解析阶段生成抽象语法树(AST);2)编译阶段将AST转换为字节码或机器码;3)执行阶段执行编译后的代码。

Python和JavaScript的未来趋势包括:1.Python将巩固在科学计算和AI领域的地位,2.JavaScript将推动Web技术发展,3.跨平台开发将成为热门,4.性能优化将是重点。两者都将继续在各自领域扩展应用场景,并在性能上有更多突破。

Python和JavaScript在开发环境上的选择都很重要。1)Python的开发环境包括PyCharm、JupyterNotebook和Anaconda,适合数据科学和快速原型开发。2)JavaScript的开发环境包括Node.js、VSCode和Webpack,适用于前端和后端开发。根据项目需求选择合适的工具可以提高开发效率和项目成功率。

是的,JavaScript的引擎核心是用C语言编写的。1)C语言提供了高效性能和底层控制,适合JavaScript引擎的开发。2)以V8引擎为例,其核心用C 编写,结合了C的效率和面向对象特性。3)JavaScript引擎的工作原理包括解析、编译和执行,C语言在这些过程中发挥关键作用。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

Dreamweaver CS6
视觉化网页开发工具

记事本++7.3.1
好用且免费的代码编辑器

Atom编辑器mac版下载
最流行的的开源编辑器

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器