What Goes Up Must Come Down

跳转链接

题目描述#

给定一个序列, 求出将此序列变换为单调递增单调递减 或者先增后减

样例1

输入
7 
3 1 4 1 5 9 2
输出
3

样例2

输入
9 
10 4 6 3 15 9 1 1 12
输出
8

分析#

本题相当于是有一个峰值, 峰值两边的都单调递减
我们可以用树状数组求出对于所有的数字处于峰值左边或者右边所需要的交换次数
对于这两种情况取一个最小值即可

CODE#

#include <iostream>
#define lowbit(i) i & -i
#define mset(a) for(int i = 0; i <= px; i ++ ) a[i] = 0

using namespace std;

const int N = 1e5 + 10;

int n, px;
int a[N], tr[N], cnt[N];

void add(int x) {
    for(int i = x; i <= px; i += lowbit(i) ) tr[i] ++;
}

int sum(int x) {
    int ans = 0;
    for(int i = x; i; i -= lowbit(i)) ans += tr[i];
    return ans;
}

int main() {
    ios::sync_with_stdio(false), cin.tie(0);
    cin >> n;
    for(int i = 1; i <= n; i ++ ) {
        cin >> a[i];
        px = max(a[i], px);
    }

    for(int i = 1; i <= n; i ++ ) {
        cnt[i] = sum(px) - sum(a[i]);
        add(a[i]);
    }
    mset(tr);
    for(int i = n; i; i -- ) {
        cnt[i] = min(sum(px) - sum(a[i]), cnt[i]);
        add(a[i]);
    }
    long long ans = 0;
    for(int i = 1; i <= n; i ++ ) ans += cnt[i];
    cout << ans << endl;
    return 0;
}
posted @   ccz9729  阅读(79)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示
主题色彩