BZOJ 1786 DP
2024-08-24 03:49:17
思路:
肯定从小往大填合适了
f[i][j]表示第i个数是j的最少逆序对数
f[i][j]=min(f[i-1][k]+cost,f[i][j])
优化一下成O(nk)就好啦~ (不优化也可以过的…)
//By SiriusRen
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int N=10005;
int n,k,a[N],f[N][105],g[N][105],vis[105],temp[105];
int main(){
scanf("%d%d",&n,&k);
for(int i=1;i<=n;i++){
scanf("%d",&a[i]);
if(~a[i])for(int j=a[i];j;j--)vis[j]++;
else for(int j=1;j<=k;j++)g[i][j]=vis[j+1];
}
memset(vis,0,sizeof(vis));
for(int i=n;i;i--){
if(~a[i]){
for(int j=a[i];j<=k;j++)vis[j]++;
for(int j=1;j<=k;j++)g[i][j]+=vis[a[i]-1];
}
else for(int j=1;j<=k;j++)g[i][j]+=vis[j-1];
}
for(int i=1;i<=n;i++){
memset(vis,0,sizeof(vis));
vis[0]=0x3f3f3f3f;
for(int j=1;j<=k;j++){
f[i][j]=g[i][j]+temp[j];
vis[j]=min(vis[j-1],f[i][j]);
}
for(int j=1;j<=k;j++)temp[j]=vis[j];
}
for(int i=2;i<=k;i++)f[n][1]=min(f[n][1],f[n][i]);
printf("%d\n",f[n][1]);
}
最新文章
- 在React 组件中使用Echarts
- 一个简易的MysQL性能查询脚本
- 【Spring-web】RestTemplate源码学习
- PHP基础教程-54课-问题
- Doc转文本
- C#中字典集合HashTable、Dictionary、ConcurrentDictionary三者区别
- gson 自定义对象转换格式
- ubuntu14.04配置中文latex完美环境(texlive+texmaker+lyx)
- Windows Thrift安装及HelloWorld
- java基于xml配置的通用excel单表数据导入组件(四、DAO主处理类)
- jdbc 日期 时间
- 【codevs】1860 最大数
- bat实现固定时间循环抓取设备log
- 【慕课网实战】Spark Streaming实时流处理项目实战笔记二十一之铭文升级版
- C 表達式及返回值
- IP地址与无符号整数值相互转换
- 历届试题 小数第n位-(同余公式+快速幂)
- TCP Socket Http关系
- LVS(Linus Virtual Server):三种负载均衡方式比较+另三种负载均衡方式
- 【Linux】Linux根目录下各文件夹的意义