每日一道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);
    }
}
相关推荐
Q741_1472 小时前
每日一题 力扣 2840. 判断通过操作能否让字符串相等 II 力扣 2839. 判断通过操作能否让字符串相等 I 找规律 字符串 C++ 题解
c++·算法·leetcode·力扣·数组·找规律
xu_wenming2 小时前
在 TinyML 场景下,如何将模型从 FP32 量化为 INT8?
arm开发·算法·iot
csdn_aspnet2 小时前
C++ 求n边凸多边形的对角线数量(Find number of diagonals in n sided convex polygon)
开发语言·c++·算法
深邃-2 小时前
字符函数和字符串函数(1)
c语言·开发语言·数据结构·c++·算法·html5
我真不是小鱼2 小时前
cpp刷题打卡记录24——路径总和 & 路径总和II
数据结构·c++·算法·leetcode
菜鸟小九2 小时前
JVM垃圾回收
java·jvm·算法
nianniannnn2 小时前
力扣 347. 前 K 个高频元素
c++·算法·leetcode
x_xbx2 小时前
LeetCode:217. 存在重复元素
数据结构·leetcode·哈希算法
漫随流水2 小时前
c++编程:求阶乘和
数据结构·c++·算法