每日一道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);
    }
}
相关推荐
浮生望3 分钟前
双指针算法面试通关指南:从入门到精通
算法
SimpleLearingAI6 分钟前
PyTorch & Numpy 实现线性回归详解
人工智能·算法·多模态大模型
papership6 分钟前
【入门级-数据结构-1、线性结构:链 表(单链表、双向链表、循环链表 )】
数据结构·算法·链表
Omics Pro8 分钟前
P4医学4大支柱需绑定4大数字技术才可落地
人工智能·python·算法·机器学习·plotly
csdn_aspnet15 分钟前
C++ 霍尔分区算法(Hoare‘s Partition Algorithm)
数据结构·c++·算法
郝学胜-神的一滴21 分钟前
力扣 144:二叉树前序遍历的优雅实现
java·数据结构·c++·python·算法·leetcode·职场和发展
MegaDataFlowers27 分钟前
543.二叉树的直径
算法
Kurisu57529 分钟前
深度拆解:从 CPU 乱序执行到内存屏障,无锁编程的底层防线
算法
GIOTTO情32 分钟前
智能舆情处置系统技术方案:基于NLP语义算法的全链路风险处置落地
人工智能·算法·自然语言处理