刷题的日常-替换字符串中的括号内容

59 阅读2分钟

开启掘金成长之旅!这是我参与「掘金日新计划 · 2 月更文挑战」的第 30 天,点击查看活动详情

刷题的日常-2023年3月4号

一天一题,保持脑子清爽

替换字符串中的括号内容

来自leetcode的 1807 题,题意如下:

给你一个字符串 s ,它包含一些括号对,每个括号中包含一个 非空 的键。

  • 比方说,字符串 "(name)is(age)yearsold" 中,有 两个 括号对,分别包含键 "name" 和 "age" 。

你知道许多键对应的值,这些关系由二维字符串数组 knowledge 表示,其中 knowledge[i] = [keyi, valuei] ,表示键 keyi 对应的值为 valuei 。

你需要替换 所有 的括号对。当你替换一个括号对,且它包含的键为 keyi 时,你需要:

  • 将 keyi 和括号用对应的值 valuei 替换。
  • 如果从 knowledge 中无法得知某个键对应的值,你需要将 keyi 和括号用问号 "?" 替换(不需要引号)。

knowledge 中每个键最多只会出现一次。s 中不会有嵌套的括号。

请你返回替换 所有 括号对后的结果字符串。

理解题意

通过题意,我们可以将信息整理如下:

  • 题目给出一个字符串,代表模板
  • 然后给出一个映射关系,代表模板字符串里参数的映射
  • 要求我们用映射关系替换模板字符串中用 括号阔起来的部分

做题思路

直接暴力解即可,步骤如下。

  • 开辟一个 Map 进行映射
  • 将映射关系存到Map中
  • 循环遍历字符串
  • 如果出现 左括号,那么往后遍历直到遇见右括号,然后从Map中查看是否有对应的映射
  • 如果有,加进字符串中,如果没有,吧 ? 加进结果中
  • 最后返回结果即可

代码实现

代码实现如下:

image.png

image.png