每日一道leetcode(2026.03.30):判断通过操作能否让字符串相等 II

每日一道leetcode(2026.03.30):判断通过操作能否让字符串相等 II

  • [1. 题目](#1. 题目)
  • [2. 分析](#2. 分析)
  • [3. 代码实现](#3. 代码实现)

1. 题目

给你两个字符串 s1s2 ,两个字符串长度都为 n ,且只包含 小写 英文字母。

你可以对两个字符串中的 任意一个 执行以下操作 任意 次:

选择两个下标 i 和 j ,满足 i < j 且 j - i 是 偶数,然后 交换 这个字符串中两个下标对应的字符。

如果你可以让字符串 s1s2 相等,那么返回 true ,否则返回 false 。

示例 1:

输入:s1 = "abcdba", s2 = "cabdab"

输出:true

解释:我们可以对 s1 执行以下操作:

  • 选择下标 i = 0 ,j = 2 ,得到字符串 s1 = "cbadba" 。
  • 选择下标 i = 2 ,j = 4 ,得到字符串 s1 = "cbbdaa" 。
  • 选择下标 i = 1 ,j = 5 ,得到字符串 s1 = "cabdab" = s2 。
    示例 2:

输入:s1 = "abe", s2 = "bea"

输出:false

解释:无法让两个字符串相等。

2. 分析

这道题其实只需要重点理解j - i 是 偶数这几个字就行了,j-i是偶数,其实表示的是ij的奇偶性相同罢了。另外还有个知识点,判断两个字符串是否可以通过移动字符位置的方式相等,可以通过将字符串的每个字符映射到26长度的字符数组后再比较,这个做法在很多算法题中都会遇到。

3. 代码实现

java 复制代码
class Solution {
    public boolean checkStrings(String s1, String s2) {
        if (s1.length() != s2.length()) {
            return false;
        }
        // 判断两个字符串中的元素是否相等
        int[] arrOdd = new int[26];
        int[] arrEven = new int[26];
        int[] arr2Odd = new int[26];
        int[] arr2Even = new int[26];
        boolean isOdd = true;
        for (int i = 0; i < s1.length(); i++) {
            if (isOdd) {
                arrOdd[s1.charAt(i) - 'a']++;
                arr2Odd[s2.charAt(i) - 'a']++;
            } else {
                arrEven[s1.charAt(i) - 'a']++;
                arr2Even[s2.charAt(i) - 'a']++;
            }
            isOdd = !isOdd;
        }
        return Arrays.equals(arrOdd, arr2Odd) && Arrays.equals(arrEven, arr2Even);
    }
}
相关推荐
浮芷.18 分钟前
微观搜打撤:基于鸿蒙flutter的内存快照算法的局内外状态隔离与高阶背包系统设计
算法·flutter·华为·开源·harmonyos·鸿蒙
郝学胜-神的一滴18 分钟前
[力扣 105]二叉树前中后序遍历精讲:原理、实现与二叉树还原
数据结构·c++·算法·leetcode·职场和发展
sheeta199822 分钟前
LeetCode 每日一题笔记 日期:2026.04.20 题目:2078.两栋颜色不同而距离最远的房子
笔记·算法·leetcode
闻缺陷则喜何志丹26 分钟前
【ST表 前缀和】P7809 [JRKSJ R2] 01 序列|普及+
c++·算法·前缀和·洛谷·st表
X journey30 分钟前
机器学习实践(18.5):特征工程补充
人工智能·算法·机器学习
LG.YDX44 分钟前
笔试训练48天:mari和shiny(动态规划 - 线性dp)
数据结构·算法
m0_564876841 小时前
提示词应用
深度学习·学习·算法
qq_283720051 小时前
Transformer 高频面试题及答案
算法·面试·transformer
承渊政道1 小时前
【递归、搜索与回溯算法】(floodfill算法:从不会做矩阵题,到真正掌握搜索扩散思想)
数据结构·c++·算法·leetcode·矩阵·dfs·bfs
谭欣辰1 小时前
字典树:高效字符串处理利器
c++·算法