JavaInterview JavaInterview
首页
指南
分类
标签
归档
  • CSDN (opens new window)
  • 文档集合 (opens new window)
  • 系统架构 (opens new window)
  • 微信号 (opens new window)
  • 公众号 (opens new window)

『Java面试+Java学习』
首页
指南
分类
标签
归档
  • CSDN (opens new window)
  • 文档集合 (opens new window)
  • 系统架构 (opens new window)
  • 微信号 (opens new window)
  • 公众号 (opens new window)
  • 指南
  • 简历

  • Java

  • 面试

  • 算法

  • algorithm
  • leetcode
JavaInterview.cn
2025-08-11
目录

1737. 满足三条件之一需改变的最少字符数Java

文章发布较早,内容可能过时,阅读注意甄别。

# 题目

给你两个字符串 a 和 b ,二者均由小写字母组成。一步操作中,你可以将 a 或 b 中的 任一字符 改变为 任一小写字母 。

操作的最终目标是满足下列三个条件 之一 :

  • a 中的 每个字母 在字母表中 严格小于 b 中的 每个字母 。
  • b 中的 每个字母 在字母表中 严格小于 a 中的 每个字母 。
  • a 和 b 都 由 同一个 字母组成。 返回达成目标所需的 最少 操作数。

示例 1:

输入:a = "aba", b = "caa"
输出:2
解释:满足每个条件的最佳方案分别是:
1) 将 b 变为 "ccc",2 次操作,满足 a 中的每个字母都小于 b 中的每个字母;
2) 将 a 变为 "bbb" 并将 b 变为 "aaa",3 次操作,满足 b 中的每个字母都小于 a 中的每个字母;
3) 将 a 变为 "aaa" 并将 b 变为 "aaa",2 次操作,满足 a 和 b 由同一个字母组成。
  最佳的方案只需要 2 次操作(满足条件 1 或者条件 3)。

示例 2:

输入:a = "dabadd", b = "cda"
输出:3
解释:满足条件 1 的最佳方案是将 b 变为 "eee" 。

提示:

  • 1 <= a.length, b.length <= 105
  • a 和 b 只由小写字母组成

# 思路

Math.min

# 解法

class Solution {
    public int minCharacters(String a, String b) {
        // 满足条件情况有三种:1、全部转换为同一个字符 2、a > b 3、a < b
        int n = a.length(), m = b.length();
        int[] chara = new int[26];
        int[] charb = new int[26];
        for (char item : a.toCharArray()) {
            chara[item - 'a']++;
        }
        for (char item : b.toCharArray()) {
            charb[item - 'a']++;
        }
        int res = n + m;
        // 1、换成同一个字符
        for (int i = 0; i < 26; i++) {
            res = Math.min(res, n + m - chara[i] - charb[i]);
        }
        for (int i = 1; i < 26; i++) {
            chara[i] += chara[i - 1];
            charb[i] += charb[i - 1];
        }
        // 枚举临界值
        for (int i = 0; i < 25; i++) {
            // 2、a中字符全部大于i b中字符全部小于等于i
            res = Math.min(res, chara[i] + m - charb[i]);
            // 3、a中字符全部小于等于i b中字符全部大于i
            res = Math.min(res, n - chara[i] + charb[i]);
            if (res == 1) System.out.println(i);
        }
        return res;
    }
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33

# 总结

  • 分析出几种情况,然后分别对各个情况实现
微信 支付宝
#Java
最近更新
01
1687. 从仓库到码头运输箱子 Java
08-11
02
1686. 石子游戏VI Java
08-11
03
1688. 比赛中的配对次数 Java
08-11
更多文章>
Theme by Vdoing | Copyright © 2019-2025 JavaInterview.cn
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式