思维,1209G1 - Into Blocks (easy version)

一、题目

1、题目描述

2、输入输出

2.1输入
2.2输出

3、原题链接

Problem - 1209G1 - Codeforces


二、解题报告

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;
}
相关推荐
Altair澳汰尔9 分钟前
数据分析和AI丨知识图谱,AI革命中数据集成和模型构建的关键推动者
人工智能·算法·机器学习·数据分析·知识图谱
A懿轩A33 分钟前
C/C++ 数据结构与算法【栈和队列】 栈+队列详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·栈和队列
Python机器学习AI38 分钟前
分类模型的预测概率解读:3D概率分布可视化的直观呈现
算法·机器学习·分类
吕小明么1 小时前
OpenAI o3 “震撼” 发布后回归技术本身的审视与进一步思考
人工智能·深度学习·算法·aigc·agi
1 9 J2 小时前
数据结构 C/C++(实验五:图)
c语言·数据结构·c++·学习·算法
程序员shen1616112 小时前
抖音短视频saas矩阵源码系统开发所需掌握的技术
java·前端·数据库·python·算法
汝即来归2 小时前
选择排序和冒泡排序;MySQL架构
数据结构·算法·排序算法
咒法师无翅鱼3 小时前
【定理证明工具调研】Coq, Isabelle and Lean.
算法
风清云淡_A3 小时前
【java基础系列】实现数字的首位交换算法
java·算法
涵涵子RUSH3 小时前
合并K个升序链表(最优解)
算法·leetcode