当前位置: 首页 > article >正文

【Leetcode 2068 】 检查两个字符串是否几乎相等 —— 击败100%

如果两个字符串 word1 和 word2 中从 'a' 到 'z' 每一个字母出现频率之差都 不超过 3 ,那么我们称这两个字符串 word1 和 word2 几乎相等 。

给你两个长度都为 n 的字符串 word1 和 word2 ,如果 word1 和 word2 几乎相等 ,请你返回 true ,否则返回 false 。

一个字母 x 的出现 频率 指的是它在字符串中出现的次数。

示例 1:

输入:word1 = "aaaa", word2 = "bccb"
输出:false
解释:字符串 "aaaa" 中有 4 个 'a' ,但是 "bccb" 中有 0 个 'a' 。
两者之差为 4 ,大于上限 3 。

示例 2:

输入:word1 = "abcdeef", word2 = "abaaacc"
输出:true
解释:word1 和 word2 中每个字母出现频率之差至多为 3 :
- 'a' 在 word1 中出现了 1 次,在 word2 中出现了 4 次,差为 3 。
- 'b' 在 word1 中出现了 1 次,在 word2 中出现了 1 次,差为 0 。
- 'c' 在 word1 中出现了 1 次,在 word2 中出现了 2 次,差为 1 。
- 'd' 在 word1 中出现了 1 次,在 word2 中出现了 0 次,差为 1 。
- 'e' 在 word1 中出现了 2 次,在 word2 中出现了 0 次,差为 2 。
- 'f' 在 word1 中出现了 1 次,在 word2 中出现了 0 次,差为 1 。

示例 3:

输入:word1 = "cccddabba", word2 = "babababab"
输出:true
解释:word1 和 word2 中每个字母出现频率之差至多为 3 :
- 'a' 在 word1 中出现了 2 次,在 word2 中出现了 4 次,差为 2 。
- 'b' 在 word1 中出现了 2 次,在 word2 中出现了 5 次,差为 3 。
- 'c' 在 word1 中出现了 3 次,在 word2 中出现了 0 次,差为 3 。
- 'd' 在 word1 中出现了 2 次,在 word2 中出现了 0 次,差为 2 。

击败100%

/*
https://leetcode.cn/u/cshappyeveryday/
执行用时:59 ms, 在所有 Typescript 提交中击败了100.00%的用户
内存消耗:52.65 MB, 在所有 Typescript 提交中击败了100.00%的用户
时间复杂度:O(n + m)
2024年8月26日 
*/
function checkAlmostEquivalent(word1: string, word2: string): boolean {
  const OFFSET = "a".charCodeAt(0);
  const cnt = new Array<number>(26).fill(0);
  for (const char of word1) {
    cnt[char.charCodeAt(0) - OFFSET]++;
  }
  for (const char of word2) {
    cnt[char.charCodeAt(0) - OFFSET]--;
  }
  return cnt.every((diff) => Math.abs(diff) <= 3);
}


http://www.kler.cn/a/280440.html

相关文章:

  • SSRF漏洞实现
  • XSS LABS - Level 1 过关思路
  • 【代码随想录训练营第42期 Day38打卡 - 动态规划Part6 - LeetCode 322. 零钱兑换 279.完全平方数 139.单词拆分
  • 【硬核】开源的高性能轻量级ORM框架
  • nacos 动态读取nacos配置中心项目配置
  • 数据结构与算法(快速基础C++版)
  • 【2024】Datawhale AI夏令营-从零上手Mobile Agent-Task1笔记
  • SpringBoot + AOP 解决审计日志记录
  • MySQL中处理JSON数据
  • 【自动驾驶】控制算法(四)坐标变换与横向误差微分方程
  • html标签大合集一文入门
  • Ubuntu 24.04 安装 intel 编译器
  • SpringBoot集成kafka-自定义拦截器(可以在拦截器中做记录日志、安全检查等操作)
  • 《上海服饰》是什么级别的期刊?是正规期刊吗?能评职称吗?
  • 垃圾分类目标检测检测系统源码分享 # [一条龙教学YOLOV8标注好的数据集一键训练_70+全套改进创新点发刊_Web前端展示]
  • iframe中postmessage重复返回多次相同信息
  • Python办公自动化实现考试系统生成Word试卷【2】
  • Redis | 非关系型数据库Redis的初步认识
  • Java | Leetcode Java题解之第372题超级次方
  • 这个神奇的网站提供各种图的R代码供您参考!