每日一道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);
    }
}
相关推荐
Hello.Reader几秒前
算法基础(十一)—— 递归树如何看懂分治算法的运行时间
java·算法·排序算法
郝学胜-神的一滴几秒前
二叉树与递归:解锁高级数据结构的编程内功心法
开发语言·数据结构·c++·算法·面试
csdn_aspnet15 分钟前
C++ (Naive Partition Algorithm)朴素划分算法
数据结构·c++·算法
eggrall16 分钟前
找到字符串中所有字母异位词(medium)
算法·leetcode·职场和发展
_日拱一卒20 分钟前
LeetCode:230二叉搜索树中第K小的元素
算法
Struggle_975526 分钟前
算法知识-背包dp
算法
ZPC821028 分钟前
Linux 共享内存(shm)
算法
水木流年追梦30 分钟前
大模型入门-应用篇2-RAG (检索增强生成):从原理到 Python 实战
开发语言·python·算法·prompt
数智工坊31 分钟前
【连续动作空间算法2】TD3:DDPG的终极进化,根治连续控制中的函数近似误差
论文阅读·人工智能·算法·计算机视觉
洛水水41 分钟前
【力扣100题】25. 搜索二维矩阵 II
算法·leetcode·矩阵