洗手间的堡垒

代码的出现2024第14天

第1部分

跟踪包装运动

在这里有很多事情要做。

>

,我相信我可以完成至少一颗金星。

我的任务似乎包括:

解析所有整数的输入生成机器人列表创建网格在modulo的帮助下,进程100移动的迭代确定每个象限的边界检查每个机器人并计算四个总和,每个象限>一个总和>总和>正如我通过算法一样,以上所有内容都可能发生变化。

是时候摇滚!

>

一次一步

使用regex将输入输入到机器人列表中

从这样的行中:
p=9,5 v=-3,-3

我想获得所有四个整数,包括负标志。

我将使用此正则表达式:

/-?d+/g

和一些数据结构操纵以获取这些值:>

let [px, py, vx, vy] = [...robot.matchall(/-?d+/g)].map(el => +el[0])

>像魅力一样工作!

设置网格

如前所述,小示例网格为11×7,而实际网格为103×101。

let width = 11let height = 7let grid =  new array(height).fill('.') .map(el => new array(width).fill('.'))

老实说,不需要网格。

>最后,我可以检查每个机器人驻留的数字范围以确定该象限的总和。

>仍然很高兴知道我可以使用网格。

>
简单而直接。

处理机器人运动和传送

正x值平均移动右移动(较高索引)。负:左。

正值y值平均向下移动(较高的索引)。负:up。

>机器人否则任何时候都会超出范围,而是让它们的行为就像移动到同一方向的网格上。

借助modulo操作员,该计算变得容易了,这给了我剩余的。

好吧,这使得从范围下向下移动。

>

>向上移动,从范围中移出将需要从网格的宽度和高度中减去。

时间将所有这些逻辑编码!

首先,循环的骨头:

for (let i = 0; i  {        let [px, py, vx, vy] = bot        if (vx < 0) {        } else {        }        if (vy < 0) {        } else {        }    })}

接下来,处理每种条件:

for (let i = 0; i  {        let [px, py, vx, vy] = bot        if (vx < 0) {            px += vx            if (px < 0) {                px = width - 1 + px            }        } else {            px = (px + vx) % (width - 1)        }        if (vy < 0) {            py += vy            if (py < 0) {                py = height - 1 + py            }        } else {            py = (py + vx) % (height - 1)        }    })}

我在不进行测试的情况下写了这篇文章。

让我们看看我必须调试多少。

好吧,第一个问题:

确保地图返回某物!
>

多么愚蠢的错误。

下一期:

在最后的其他条款中,我错误地引用了vx,而不是vy另一个愚蠢的错误!

幸运的是,这些似乎是我唯一的错误。

>

>我现在使用此代码看到了预期的电网量:>

robots.foreach(bot => {    let [px, py] = bot    if (grid[py][px] == 1) {        grid[py][px] = 2    } else {        grid[py][px] = 1    }})console.log(grid.map(line => line.join('')).join('n'))

对每个象限进行计数示例网格为11×7。象限范围为:

0,0 to 0,42,0 to 2,40,6 to 0,102,6 to 2,104,0 to 4,46,0 to 6,44,6 to 4,106,6 to 6,10

数字都是均匀的。

数字等于:
>之一

的侧长除以两个:圆形和减去一个或舍入

>

侧长度减去一个

我可以通过一系列非常复杂的条件子句解决此问题。>

,我将:

let quads = [0,0,0,0]robots.foreach(([px, py]) => {    if (px <= (math.floor(width / 2) - 1)) {        // left half        if (py = math.ceil(height / 2)) {            // bottom quadrant            quads[1]++        }    } else if (px >= (math.ceil(width / 2))) {        // right half        if (py = math.ceil(height / 2)) {            // bottom quadrant            quads[3]++        }    }})

最后,每个tall的乘积:

quads.reduce((a, c) => a * c)

跑步和希望>为示例输入生成12吗?是!

它会生成

我的难题输入吗?

是的!不过,这是真正的。

让我检查每个象限的价值。

每个都超过一百。

有500个机器人。

>我敢肯定有几个落在水平或垂直的中点上。

这个数字可能是正确的。

>提交… 是对的!!!

woohoo !!!

我觉得这将是一个检查点式的挑战,其中第2部分是真正的难题。

等不及要看。

第2部分

哦,酷,我可以模拟机器人!

据说它们在某个时候形成了一棵圣诞树。

可能是几秒钟。

可能是数百个。

是时候构建我的第一个模拟器2024!

>

构建模拟器

这很容易。

我使用codepen.io。

网格很小,可以适合宽屏。

>但有效:

增强模拟器

按下按钮执行迭代

我按了一束,看到了两个经常性的模式>

我想知道机器人以其初始状态重新启动需要多少迭代

我使用set()跟踪每个状态

我使用setinterval()以快速pace

自动识别

我添加了一个列表以显示重复状态

>我按下按钮,看着数量爬入数千个

simulator of robot movement> 10k之后,机器人返回其起始状态

为了确认这一点,我扭转了每个机器人速度的极性>

>我再次按下按钮,看着它爬入数千个,当机器人启动新循环

时看到了相同的迭代号码我现在知道我的拼图输入循环中的机器人每10403迭代一次。 作弊,或者让我的眼睛紧张>我真的不想手动浏览所有10403迭代,寻找圣诞树。我知道我可以提交4个答案,并提示我的提交太高还是低。我很想进行四个二进制搜索:提交5000并检查高或低>提交2500或7500,然后检查高或低提交1200或3700或6300或8800,然后检查高或低>再次提交并检查然后,我只需要检查几百个州,而不是10000个州。>,如果它接近10403,而不是0,我可以通过使我的计数从那里开始并倒数来解释。>

我要去做:

提交5201:太低

提交的7803:太高

>

提交的6502:太低

>

正确的答案在6502和7803之间那是1300个国家,我的眼睛可怜。比超过10k好,对吗? 我看到了!我添加了一些按钮以快速进度,然后慢>我加速了6500迭代然后,我仔细地看着接下来的几百

我试图用一只眼睛眨眼,所以我不会错过这棵树

然后,突然间,它出现了!

我暂停了计时器,看到了7612

>之前一定是几个步骤是时候重新启动和手动行走,从7500开始 我又看到了!我不得不再回去几次:

一次,因为我错误地连接了我的新按钮

>又是因为我超越了加速的迭代

,但是,最终,我用图片停在状态下了: 我从来没有更高兴看到ascii圣诞树。>我的柜台是正确的 – 这个数字是我正确的答案。>我不知道我将如何解决此算法。>,但这真的很有趣。>即使我必须利用错误的提交来执行一种二进制搜索以找到答案。这是运行的全部部分,对吗?!>我自豪地将我的两个金星带到第15天。

以上就是洗手间的堡垒的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1501494.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 23:36:33
下一篇 2025年12月19日 23:36:44

相关推荐

  • 与NextJS集成的Redsys介绍15

    如今,众多企业寻求在线盈利途径,例如SaaS、电商或其他网络应用。虽然Stripe和PayPal等全球支付平台普及,但不同国家/地区偏好各有不同。在西班牙,Redsys几乎主导所有在线银行交易。Redsys是一个基于SOAP API的平台,旨在简化和保障西班牙银行网络的数字支付。尽管功能强大,但其独…

    2025年12月19日
    000
  • 在不到两分钟的时间内旋转新铁路上的许可证密钥API!

    Railway 的新功能特性让部署单文件微服务变得轻而易举,无需管理基础设施或代码库。本文将演示如何使用 Hono、Redis 和 Bun 运行时,在一个文件中构建一个许可证 API。准备开始构建吧! 注意: Railway 功能非常适合处理小型任务,例如网络钩子、cron 作业或简单的 API。它…

    2025年12月19日
    000
  • 您是在犯这些Nodejs安全错误吗?

    介绍 >在2016年,当黑客通过利用私人github存储库中的暴露凭据访问其aws s3服务器时,uber面临严重的安全漏洞。该服务器包含5700万用户和60万驱动程序的敏感数据。违规发生是由于不良的访问控制和凭证管理在其node.js应用程序中。如果像uber这样的技术巨头可能会发生这种情况…

    好文分享 2025年12月19日
    000
  • 双向将信号输入对象值绑定为[(ngmodel)]

    最近,我遇到了这一挑战…重构形式成分的角度信号。 旧形式组件的工作原理: > 表单数据来自反应性状态服务>表单数据是对象>在将其传递给form component>之前,将其形式数据克隆到克隆之前表单组件通过一个基于经典的装饰 angular @input 接收表…

    2025年12月19日
    000
  • JavaScript对象魔术

    本文探讨JavaScript对象赋值的特性及其潜在问题,并提供解决方案。 对象赋值与引用: 以下代码片段演示了JavaScript对象赋值的机制: const person = { firstname: ‘ajay’, lastname: ‘kumar’, hobbies: [‘cricket’, …

    2025年12月19日
    000
  • 第三方图书馆的隐藏成本:当&#don&#t重新发明车轮&#错误

    程序员奉为圭臬的信条之一是“不要重复造轮子”。然而,如同软件开发中的许多绝对性断言一样,实际情况远比这复杂。本文将探讨引入看似便捷的npm包时,其成本可能远高于自行编写代码的情况。 免费代码的陷阱 我们都经历过:需要实现某个功能,恰好有一个npm包能完美胜任。它很流行,维护良好,只需npm inst…

    2025年12月19日
    000
  • 容器安全市场将达到2美元

    全球市场研究机构CrediculousResearch®发布的报告《集装箱安全市场——全球机遇分析与行业预测(2025-2032)》指出,到2032年,集装箱安全市场规模预计将达到127.5亿美元,2025年至2032年的复合年增长率为23.6%。 AI和ML技术在容器安全解决方案中的广泛应用、对云…

    2025年12月19日
    000
  • 使用开放的Web服务发布订阅消息传递

    本文将演示如何利用eyevinn开源云提供的开放式web服务构建一个发布/订阅消息传递(pub/sub)应用程序。pub/sub是一种异步通信模型,是构建可扩展和分布式系统的重要组成部分。我们将使用valkey,一个基于eyevinn开源云的开放式web服务,来实现此功能。 本教程将指导您完成以下步…

    2025年12月19日
    000
  • 浅副本和深副本

    浅拷贝与深拷贝:JavaScript 对象复制详解 本文深入探讨 javascript 中的浅拷贝和深拷贝,并通过示例代码清晰地展现两者之间的差异。理解这两种拷贝方式对于避免潜在的程序错误至关重要。 1. 浅拷贝 浅拷贝创建一个新对象,但只复制顶层属性。对于嵌套对象或数组,浅拷贝只复制其引用,而非创…

    2025年12月19日
    000
  • 保持用户的同步:与凸的实时协作

    我的创业公司stick,一款实时协作白板应用,灵感源于线下协作的便捷性。stick的开发过程既富有挑战性,也令人兴奋。在完成项目后,我积累了大量经验,涵盖用户同步、高效数据处理以及系统稳定性保障等方面。 实时协作的必要性 实时协作对现代工作流程至关重要,无论是头脑风暴、文档编辑还是代码调试,即时反馈…

    2025年12月19日
    000
  • 从混乱到清晰:掌握Web应用程序中的JSON数据处理

    高效处理巨型JSON数据,轻松构建卓越Web应用!还记得第一次处理API返回的庞大JSON数据包的场景吗?无尽的嵌套对象和数组令人望而生畏,我的应用难以胜任。 这促使我深入研究JSON数据处理的技巧:解析、转换和展示。 本文将分享我的经验,助您将JSON数据混乱转化为清晰、易用的信息,无论您是新手还…

    2025年12月19日
    000
  • 管理React子域的路线和导航

    本教程延续上一篇,讲解如何在React子域中管理路由和导航,实现不同布局间的无缝切换。我们将使用React Router来完成这项任务。 React Router与布局管理 由于React是单页应用(SPA)框架,高效的导航管理至关重要。React Router允许为不同路由定义不同的布局,非常适合…

    2025年12月19日
    000
  • NextJS重定向到另一页教程

    Next.js 提供多种方法实现页面重定向,无论您构建的是客户端还是服务器端应用,都能轻松实现页面间的无缝跳转。本指南将介绍几种基于最新文档的 Next.js 重定向方法。 使用 redirect() 函数(服务器组件和 API 路由) Next.js 内置的 redirect() 函数主要用于服务…

    2025年12月19日
    000
  • 与发bun活着重新加载html

    this article demonstrates how to create a simple live reload mechanism for html content using bun’s built-in http server and server-sent events …

    2025年12月19日
    000
  • 如何从JavaScript数组和字符串中删除重复值

    在JavaScript应用开发中,重复数据问题时常出现,例如用户列表中的重复名称或句子中的重复单词。 本文将介绍几种高效移除JavaScript数组和字符串中重复值的方法,并分析其优缺点及应用场景。 从数组中删除重复项 方法一:使用Set对象 Set对象是处理重复数据的利器,其特性是不允许重复值。 …

    2025年12月19日
    000
  • 飞地游戏月度报告:1月5日

    一月gamedev.js回顾:调查结果、游戏果酱和更多! 一月通常是GameDev.js较为平静的一个月,因为大部分精力都放在处理非手机相关的项目上。年度GameDev.js调查报告也在一月发布(调查本身在十二月进行)。但即便如此,这个月依然有不少值得关注的动态: 游戏方面:本月没有发布新的游戏。 …

    2025年12月19日
    000
  • 与Sveltekit挑战Devchallengesio

    本文分享了我使用SvelteKit完成DevChallenges.io项目“简单咖啡列表”的经验。在此之前,我要感谢大家对之前文章的支持!这次,我尝试使用SvelteKit框架,因为它与我之前使用的PHP框架截然不同,并希望扩展我的JavaScript技能。 我选择DevChallenges.io是…

    2025年12月19日
    000
  • 每个开发人员都应该知道的顶级美食

    JavaScript,全球最流行的编程语言之一,其影响力持续增长。ES6(ECMAScript 2015)为JavaScript引入了诸多令人兴奋的新特性。本文将介绍十个JavaScript开发者必须掌握的ES6高级特性,助您在编程领域保持领先地位。无论您是新手还是资深开发者,这些特性都能提升您的J…

    好文分享 2025年12月19日
    000
  • 理解JavaScript中的对象

    JavaScript对象是八种基本数据类型中的一种。不同于数字、字符串、布尔值等只存储单个值的原始数据类型,对象可以存储多个值,这些值以键值对的形式组织成属性。键通常是字符串或Symbol类型,值可以是任何数据类型。 对象初始化 const myObj = new Object();const my…

    2025年12月19日
    000
  • 以不同的方式逆转数组

    JavaScript 提供多种方法逆转数组。本文将介绍几种常用的方法,并比较其优缺点。 1. 使用 reverse() 方法: reverse() 方法是最直接、最简洁的数组反转方法。它直接修改原始数组,不创建新的数组。 示例: const arr = [5, 2, 3, 7, 9, 15, 20]…

    2025年12月19日
    000

发表回复

登录后才能评论
关注微信