思维,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;
}
相关推荐
Yingye Zhu(HPXXZYY)2 小时前
ICPC 2023 Nanjing R L 题 Elevator
算法
程序员Xu6 小时前
【LeetCode热题100道笔记】二叉树的右视图
笔记·算法·leetcode
笑脸惹桃花6 小时前
50系显卡训练深度学习YOLO等算法报错的解决方法
深度学习·算法·yolo·torch·cuda
阿维的博客日记6 小时前
LeetCode 48 - 旋转图像算法详解(全网最优雅的Java算法
算法·leetcode
GEO_YScsn7 小时前
Rust 的生命周期与借用检查:安全性深度保障的基石
网络·算法
程序员Xu7 小时前
【LeetCode热题100道笔记】二叉搜索树中第 K 小的元素
笔记·算法·leetcode
THMAIL8 小时前
机器学习从入门到精通 - 数据预处理实战秘籍:清洗、转换与特征工程入门
人工智能·python·算法·机器学习·数据挖掘·逻辑回归
Kevinhbr8 小时前
CSP-J/S IS COMING
数据结构·c++·算法
蕓晨8 小时前
set的插入和pair的用法
c++·算法
THMAIL9 小时前
深度学习从入门到精通 - AutoML与神经网络搜索(NAS):自动化模型设计未来
人工智能·python·深度学习·神经网络·算法·机器学习·逻辑回归