CF1215E Marbles

本文介绍了一种使用状压动态规划解决序列排序问题的方法,重点在于如何通过计算逆序对数量来确定排序所需的最小交换次数。文章详细解释了算法思路,并提供了完整的代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

CF1215E Marbles

传送门

思路

一道比较有意思的状压dp。

首先有一个结论,把一个序列通过交换相邻元素排序,那么交换次数的最小值就是逆序对个数

证明:从小到大依次把元素换到最前面,那么每次交换都会使逆序对个数-1。逆序对为0则为有序。

考虑引入一个\(a_{c_i}\)代表\(c_i\)这种颜色在序列中的排名。

考虑按照\(a_i\)大小依次考虑每个\(c\)。dp数组中存储了以及被用过的\(c\)。而\(dp[3]=d[(101)_2]\)代表\(c=3\space or\space c=1\)的放在序列前两个位置,最少需要交换多少次。

对于\(dp[i]\),我们枚举从哪个状态加入一种\(c\)转移过来,令来源状态为\(j\),加入的颜色为\(k\)\(i\)\(j\)的基础上多了一个1。那么显然\(dp[i]=min(dp[j]+\sum_{v\in j}w[k][v])\)。其中\(w[k][v]\)就是原序列中\(k,v\)形成的逆序对个数(令\(a_k>a_v\))。

代码

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#define ll long long
const int maxn=4e5+100;
using namespace std;
int n,a[maxn],cnt[22];
ll w[22][22],dp[1<<21],sum;
int main(){
    ios::sync_with_stdio(0);
    cin>>n;int set=1<<21, mx = 0;
    for(int i=1;i<=n;i++)cin>>a[i], mx = max(mx, a[i]);
    for(int i=1;i<=n;i++){
        cnt[a[i]]++;
        for(int j=0;j<=20;j++){
            if(j==a[i])continue;
            w[j][a[i]]+=cnt[j];
        }
    }
    set = 1 << (mx + 1);
    for(int i=1;i<set;i++){
        dp[i]=1e18;
        for(int j=0;j<=mx;j++){
            if((1<<j)&i){
                int tmp=i^(1<<j);
                sum=0;
                for(int k=0;k<=mx;k++){
                    if(((1<<k)&tmp)){
                        sum+=w[j][k];
                        if (dp[tmp] + sum >= dp[i]) break;  
                    }
                }
                dp[i]=min(dp[i],dp[tmp]+sum);
            }
        }
    }
    cout<<dp[set-1];
    return 0;
}

1669439-20190925221845073-1453692579.jpg

转载于:https://www.cnblogs.com/GavinZheng/p/11588034.html

内容概要:本文探讨了在MATLAB/SimuLink环境中进行三相STATCOM(静态同步补偿器)无功补偿的技术方法及其仿真过程。首先介绍了STATCOM作为无功功率补偿装置的工作原理,即通过调节交流电压的幅值和相位来实现对无功功率的有效管理。接着详细描述了在MATLAB/SimuLink平台下构建三相STATCOM仿真模型的具体步骤,包括创建新模型、添加电源和负载、搭建主电路、加入控制模块以及完成整个电路的连接。然后阐述了如何通过对STATCOM输出电压和电流的精确调控达到无功补偿的目的,并展示了具体的仿真结果分析方法,如读取仿真数据、提取关键参数、绘制无功功率变化曲线等。最后指出,这种技术可以显著提升电力系统的稳定性与电能质量,展望了STATCOM在未来的发展潜力。 适合人群:电气工程专业学生、从事电力系统相关工作的技术人员、希望深入了解无功补偿技术的研究人员。 使用场景及目标:适用于想要掌握MATLAB/SimuLink软件操作技能的人群,特别是那些专注于电力电子领域的从业者;旨在帮助他们学会建立复杂的电力系统仿真模型,以便更好地理解STATCOM的工作机制,进而优化实际项目中的无功补偿方案。 其他说明:文中提供的实例代码可以帮助读者直观地了解如何从零开始构建一个完整的三相STATCOM仿真环境,并通过图形化的方式展示无功补偿的效果,便于进一步的学习与研究。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值