博客
关于我
Codeforces 1199D-Welfare State【思维】
阅读量:277 次
发布时间:2019-03-01

本文共 1444 字,大约阅读时间需要 4 分钟。

数组操作问题解决方案

在这个问题中,我们需要处理一个大小为n的数组,并对它执行q次操作。操作分为两种:操作1用于修改数组中的特定位置的值,操作2用于将数组中所有小于某个值的元素修改为该值。我们的目标是根据这些操作,确定数组中每个位置的最终值。

问题分析

  • 操作类型

    • 操作1 (p, x):将数组中第p个位置的值修改为x。
    • 操作2 (x):将数组中所有小于x的元素修改为x。
  • 挑战

    • 操作2可能对多个位置产生影响,且后续的操作2可能会覆盖前面的影响。
    • 直接模拟每次操作2会导致高时间复杂度,尤其是在n很大的情况下。
  • 优化思路

    • 使用辅助数组记录操作信息:
      • last[i] 记录第i个位置最后一次被操作1修改的操作编号。
      • lastX[i] 记录第i个位置最后一次被操作1修改的值。
      • lastAllToX[i] 记录第i次操作2之后的最大x值。
  • 关键步骤

    • 处理操作1时,记录修改的位置和值。
    • 处理操作2时,记录每次操作的x值,并从后向前遍历更新最大x值。
    • 最终每个位置的值由lastX[i]lastAllToX[last[i]]中的最大值决定。
  • 解决方案代码

    #include 
    using namespace std;const int maxn = 200100;int last[maxn], lastX[maxn], lastAllToX[maxn];int main() { int n, q, op, p, x; cin >> n; for (int i = 1; i <= n; ++i) { cin >> lastX[i]; } cin >> q; for (int i = 0; i < q; ++i) { cin >> op; if (op == 1) { cin >> p >> x; last[p] = i; lastX[p] = x; } else { cin >> x; lastAllToX[i] = x; } } for (int i = q - 1; i >= 0; --i) { if (lastAllToX[i] < lastAllToX[i + 1]) { lastAllToX[i] = lastAllToX[i + 1]; } } for (int i = 1; i <= n; ++i) { int res = max(lastX[i], lastAllToX[last[i]]); cout << res << " "; } cout << endl;}

    代码解释

  • 输入处理

    • 读取数组大小n和操作次数q。
    • 初始化lastX数组,读取初始数组值。
  • 处理操作

    • 对于操作1,记录修改的位置和值。
    • 对于操作2,记录每次操作的x值。
  • 构建最大值数组

    • 从后向前遍历操作2记录,更新每个位置的最大x值。
  • 计算最终值

    • 每个位置的最终值由最后一次操作1和后续操作2的最大x值决定。
  • 这种方法确保了在处理大规模数据时的高效性,避免了直接模拟操作2对所有元素的修改,实现了时间复杂度为O(n + q)的优化。

    转载地址:http://tvio.baihongyu.com/

    你可能感兴趣的文章
    OpenCV VideoCapture.get()参数详解
    查看>>
    opencv videocapture读取视频cap.isOpened 输出总是false
    查看>>
    opencv waitKey() 函数理解及应用
    查看>>
    OpenCV 中的图像转换
    查看>>
    OpenCV 人脸识别 C++实例代码
    查看>>
    OpenCV 在 Linux 上的 python 与 anaconda 无法正常工作.收到未实现 cv2.imshow() 的错误
    查看>>
    Opencv 完美配置攻略 2014 (Win8.1 + Opencv 2.4.8 + VS 2013)上
    查看>>
    opencv 模板匹配, 已解决模板过大程序不工作的bug
    查看>>
    OpenCV 错误:(-215)size.width>0 &&函数imshow中的size.height>0
    查看>>
    opencv&Python——多种边缘检测
    查看>>
    opencv&python——高通滤波器和低通滤波器
    查看>>
    OpenCV+Python识别车牌和字符分割的实现
    查看>>
    OpenCV-Python接口、cv和cv2的性能比较
    查看>>
    OpenCV/Python/dlib眨眼检测
    查看>>
    opencv1-加载、修改、保存图像
    查看>>
    opencv10-形态学操作
    查看>>
    opencv11-提取水平直线和垂直直线
    查看>>
    opencv12-图像金字塔
    查看>>
    opencv13-基本阈值操作
    查看>>
    opencv14-自定义线性滤波
    查看>>