一、题目
1、题目描述
2、输入输出
2.1输入
2.2输出
3、原题链接
二、解题报告
1、思路分析
考虑:
最终状态为若干段相同数字,且任意两段数字不同
每个数字出现的最左下标和最右下标构成一个区间
连锁反应------有交集的区间的并集内的数字都会变一样
那么合并区间即可,最终每个区间的贡献就是区间长度减去区间内最大数字出现次数
2、复杂度
时间复杂度: O(N)空间复杂度:O(N)
3、代码详解
cpp
#include <bits/stdc++.h>
using PII = std::pair<int, int>;
using i64 = long long;
void solve() {
const int M = 2e5 + 10;
int N, Q;
std::cin >> N >> Q;
std::vector<int> nums(N), suf(M), cnt(M);
for (int i = 0; i < N; i ++ ) {
std::cin >> nums[i];
suf[nums[i]] = i, cnt[nums[i]] ++;
}
int res = 0, l = 0, r = 0, ma = 0;
for (int i = 0; i < N; i ++ ) {
if (r < i) {
res += r - l + 1 - ma;
ma = 0;
l = r = i;
}
// std::cout << l << " " << r << '\n';
if (suf[nums[i]] > r) r = suf[nums[i]];
if (cnt[nums[i]] > ma) ma = cnt[nums[i]];
}
res += r - l + 1 - ma;
std::cout << res;
}
int main () {
std::ios::sync_with_stdio(false); std::cin.tie(0); std::cout.tie(0);
int _ = 1;
// std::cin >> _;
while (_ --)
solve();
return 0;
}