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

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

题目

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
给你两个字符串 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 只由小写字母组成

题目思路

  • 1、前缀和以及计数的思想
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
class Solution {
public:
int minCharacters(string a, string b) {
int n = a.size(), m = b.size();
int l[26] = {0};
int r[26] = {0};
for(auto x : a)
{
l[x - 'a']++;
}
for(auto x : b)
{
r[x - 'a']++;
}
int ls = 0;
int rs = 0;
int ans = n + m;
for (int i = 0; i < 25; ++i)
{
ls += l[i];
rs += r[i];
ans = min(ans, min(min(n + m - l[i] - r[i], n - ls + rs), m - rs + ls));
}
ans = min(ans, n + m - l[25] - r[25]);
return ans;
}
};

复杂度

  • 时间复杂度:O(n)

  • 空间复杂度:O(n)


Day 35 1737. 满足三条件之一需改变的最少字符数
https://chaggle.github.io/2021/10/14/Leetcode/91-day/day-35/
作者
chaggle
发布于
2021年10月14日
许可协议