博客
关于我
Codeforces Round #618 (Div. 1) C. Water Balance(思维+单调栈)
阅读量:393 次
发布时间:2019-03-05

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

如何使数组的字典序最小

给定n个数,每次可以选择任意区间,将区间内的所有数变成平均数,目标是通过一系列操作使得整个数组的字典序最小。字典序最小意味着数组从左到右每个数尽可能小。以下是解决方案:

  • 从后往前处理:为了使前面的数尽可能小,首先处理后面的数。处理后面的数后,前面的数可能也会因为某些操作而被降低。

  • 记录区间:使用一个数组size来记录当前处理的区间。size[i]表示从i开始到某个j结束的区间。当处理到i时,size[i]的值告诉你当前处理的区间的右端点。

  • 遍历数组:从右到左遍历数组。对于每个i,计算从i到j的区间,其中j是i后面最大的处理点。然后在这个区间内计算平均值,并将所有数设置为这个平均值。同时,记录当前的区间,方便后续处理。

  • 维护size数组:在处理每个i时,更新size数组,确保每个i都知道自己处理的区间。例如,size[3]=size[6]=6,表示i=3已经和后面的数处理过了。

  • 以下是具体实现步骤:

    • 初始化size数组,size[i]=i。
    • 从n-1遍历到1:
      • 计算从i到j的区间,其中j是i后面最大的处理点。
      • 计算区间内的平均值。
      • 将区间内的所有数设置为平均值。
      • 更新size数组,记录当前的区间。

    通过这种方法,可以确保每次操作都能带来最大的降低效果,从而使得整个数组的字典序最小。

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

    你可能感兴趣的文章
    No qualifying bean of type ‘com.netflix.discovery.AbstractDiscoveryClientOptionalArgs<?>‘ available
    查看>>
    No resource identifier found for attribute 'srcCompat' in package的解决办法
    查看>>
    no session found for current thread
    查看>>
    No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
    查看>>
    NO.23 ZenTaoPHP目录结构
    查看>>
    no1
    查看>>
    NO32 网络层次及OSI7层模型--TCP三次握手四次断开--子网划分
    查看>>
    NOAA(美国海洋和大气管理局)气象数据获取与POI点数据获取
    查看>>
    NoClassDefFoundError: org/springframework/boot/context/properties/ConfigurationBeanFactoryMetadata
    查看>>
    node exporter完整版
    查看>>
    Node JS: < 一> 初识Node JS
    查看>>
    Node Sass does not yet support your current environment: Windows 64-bit with Unsupported runtime(72)
    查看>>
    Node 裁切图片的方法
    查看>>
    Node+Express连接mysql实现增删改查
    查看>>
    node, nvm, npm,pnpm,以前简单的前端环境为什么越来越复杂
    查看>>
    Node-RED中Button按钮组件和TextInput文字输入组件的使用
    查看>>
    Node-RED中Switch开关和Dropdown选择组件的使用
    查看>>
    Node-RED中使用html节点爬取HTML网页资料之爬取Node-RED的最新版本
    查看>>
    Node-RED中使用JSON数据建立web网站
    查看>>
    Node-RED中使用json节点解析JSON数据
    查看>>