0

0

仔细考虑一下

心靈之曲

心靈之曲

发布时间:2024-12-04 14:27:02

|

685人浏览过

|

来源于dev.to

转载

仔细考虑一下

代码来临 2024 年第 3 天

第 1 部分

我担心第二部分

我看了一眼谜题输入,感到非常害怕。

然后我读了第 1 部分我必须做的事情并暂时放松了:

  • 只需找到 mul(n,n) 的所有实例

我可以使用简单的正则表达式来做到这一点!

使用正则表达式查找所有有效的 muls

我必须记住转义括号,然后我得到了这个有效的正则表达式:

/mul\((\d*),(\d*)\)/g
  • 这匹配所有有效的 mul 部分
  • 并为每对中的每个数字创建捕获组

现在我需要对每场比赛进行适当的提取和数学计算

编写算法

这是完整的工作代码:

let total = [...input.matchall(/mul\((\d*),(\d*)\)/g)].reduce(
  (total, match) => {
    total += match
      .slice(1, 3)
      .map(number)
      .reduce((a, b) => a * b);
    return total;
  },
  0
);
  • 它找到所有匹配项并将它们分散到一个数组中
  • 然后迭代每一个,从 0 开始累加一个值
  • 对于每场比赛,它仅抓取索引为 1 和 2 的两个捕获组
  • 将它们转换为数字
  • 将它们简化为产品
  • 并将该金额添加到总计中

它为示例输入生成正确的答案。

尝试我的拼图输入会生成...

正确答案!!!

深呼吸............

............第 2 部分

第2部分

哦,那还不错

我认为由于输入充满了不同的单词,因此它将添加各种新规则来解释。

幸运的是,只有两个新单词充当有效 mul 语句的开始和结束。

现在感觉就像是通过索引每个 do() 和 dont() 并搜索要解析的 mul 语句的正确部分来隔离每个有效语句的练习。

索引条件标志

我想使用正则表达式来匹配所有出现的 do() 和 don():

/don't\(\)|do\(\)/g

这样,我应该沿着输入字符串的路径有交替的检查点。

如果是这样,我可以提取 do() 和 dont() 检查点之间的子字符串,并检查 muls。

让我确认示例和完整输入。

这是我隔离标志及其索引的算法:

let flags = [...input.matchall(/don't\(\)|do\(\)/g)].map((el) => {
  return [el[0], el.index];
});

确认:

DM6在线读报系统
DM6在线读报系统

DM6在线读报系统ASPX 免费版2.0。如果您是一个DM广告公司的网站管理员,正在寻求一套程序或源码可以让公司网站具有一套配合网站整体架构的电子杂志频道,那您现在可找对了。请仔细阅读以下关于DM6在线读报系统的说明。 这是一个网站用户可以直接在线阅读报纸且无需插件(连Flash都不用)、无需下载、无需安装的在线读报系统(服务器端模块),通过将此系统放到网站文件目录中即可轻松生成网站的在线读报频道

下载
  • 示例中的交替条件
  • 我的输入中没有可信模式:连续多个 do() 和 don()

这变得有点复杂了。

新战略

自从事情开始启用以来,我必须从索引 0 开始抓取,直到第一个 don()。所以,我需要找到它的索引。并检查该子字符串。

从那时起,我可以跳过所有后续的 don(),并寻找下一个 do()。

以此作为我的新起始索引,我需要找到下一个 don()。那是我的新终点。检查该子字符串。

然后重复:查找下一个 do(),查找下一个 don(),检查子字符串。

这感觉就像一个 while 循环。

当我编写算法时我会知道更多。

新的、更长的算法

很多条件来处理缺乏模式的“做-不该做”的发生顺序:

let total = 0;
let start = 0;
let end = 0;
let flag = true;
let i = 0;
while (i < flags.length) {
  if (flag) {
    // find next don't()
    if (flags[i][0] == "don't()") {
      // set new end
      end = flags[i][1];
      // swap flag
      flag = false;
      // calculate muls in substring
      total += [
        ...input.slice(start, end).matchAll(/mul\((\d*),(\d*)\)/g),
      ].reduce((total, match) => {
        total += match
          .slice(1, 3)
          .map(Number)
          .reduce((a, b) => a * b);
        return total;
      }, 0);
    } else {
      // keep walking the array
      i++;
    }
  } else {
    // find next do()
    if (flags[i][0] == "do()") {
      // set new start
      start = flags[i][1];
      // swap flag
      flag = true;
      // keep walking the array
      i++;
    } else {
      // keep walking the array
      i++;
    }
  }
}
// calculate muls for the last substring
total += [...input.slice(start).matchAll(/mul\((\d*),(\d*)\)/g)].reduce(
  (total, match) => {
    total += match
      .slice(1, 3)
      .map(Number)
      .reduce((a, b) => a * b);
    return total;
  },
  0
);

令我惊喜的是,它为示例输入生成了正确的答案。

处理我的拼图输入后会生成什么?

...

正确答案!!!

在检查之前,我添加了一个控制台日志记录语句来确认要检查的子字符串的每个开始和结束索引。

我将它们与数组中标志的顺序进行了比较。

一切看起来都不错,所以我提交了。

并得到了正确答案!

多么令人愉快和有益的感觉!

又是一个早起的一天。又一颗来之不易的两颗金星。

进入第四天!

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

510

2023.06.20

正则表达式不包含
正则表达式不包含

正则表达式,又称规则表达式,,是一种文本模式,包括普通字符和特殊字符,是计算机科学的一个概念。正则表达式使用单个字符串来描述、匹配一系列匹配某个句法规则的字符串,通常被用来检索、替换那些符合某个模式的文本。php中文网给大家带来了有关正则表达式的相关教程以及文章,希望对大家能有所帮助。

249

2023.07.05

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

742

2023.07.05

java正则表达式匹配字符串
java正则表达式匹配字符串

在Java中,我们可以使用正则表达式来匹配字符串。本专题为大家带来java正则表达式匹配字符串的相关内容,帮助大家解决问题。

213

2023.08.11

正则表达式空格
正则表达式空格

正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。本专题为大家提供正则表达式相关的文章、下载、课程内容,供大家免费下载体验。

351

2023.08.31

Python爬虫获取数据的方法
Python爬虫获取数据的方法

Python爬虫可以通过请求库发送HTTP请求、解析库解析HTML、正则表达式提取数据,或使用数据抓取框架来获取数据。更多关于Python爬虫相关知识。详情阅读本专题下面的文章。php中文网欢迎大家前来学习。

293

2023.11.13

正则表达式空格如何表示
正则表达式空格如何表示

正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。想了解更多正则表达式空格怎么表示的内容,可以访问下面的文章。

234

2023.11.17

正则表达式中如何匹配数字
正则表达式中如何匹配数字

正则表达式中可以通过匹配单个数字、匹配多个数字、匹配固定长度的数字、匹配整数和小数、匹配负数和匹配科学计数法表示的数字的方法匹配数字。更多关于正则表达式的相关知识详情请看本专题下面的文章。php中文网欢迎大家前来学习。

528

2023.12.06

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

8

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号