Codeforces Round #585 (Div. 2)E(状态压缩DP,思维)
#define HAVE_STRUCT_TIMESPEC
#include<bits/stdc++.h>
using namespace std;
long long n,x;
long long num[21],f[1<<20],g[21][21];
int main(){
cin>>n;
for(;n--;){
cin>>x;
++num[--x];//计数--x出现的次数
for(int i=0;i<20;++i)//将x全部放置在相对位置i前面
g[x][i]+=num[i];//num[i]为x前面颜色i的个数
}
for(int i=1;i<1<<20;++i)
f[i]=1e18;
//memset(f,1,sizeof(f));//全部初始为一个很大的值
//f[0]=0;
for(int i=0;i<1<<20;++i)//遍历每一种排列
for(int j=0;j<20;++j)//遍历在i前面的颜色j
if(!(i>>j&1)){//i中如果已经有j就不需要计算了
long long tmp=f[i];//排好i序列的次数
for(int k=0;k<20;++k)
if(i>>k&1)//哪一位上已经排好
tmp+=g[j][k];//加上把j排在k前面的次数
f[i|(1<<j)]=min(f[i|(1<<j)],tmp);//更新把j排在i前面序列的最小值
}
cout<<f[(1<<20)-1];
}
/*#define HAVE_STRUCT_TIMESPEC
#include<bits/stdc++.h>
using namespace std;
int a[400007];
int c[400007];
long long f[(1<<20)+7];
long long dp[(1<<20)+7][27];
int cnt[27];
int main(){
int n;
cin>>n;
for(int i=1;i<=n;++i){
cin>>a[i];
c[i]=a[i];
}
sort(c+1,c+1+n);//将a数组复制到c并排序
int m=unique(c+1,c+1+n)-c-1;//找出c数组中不同元素的个数
for(int i=1;i<=n;++i)
a[i]=lower_bound(c+1,c+1+m,a[i])-c;//将a数组改成原本元素最早出现的位置
for(int i=1;i<=n;++i){
++cnt[a[i]];//计数最早出现在该位置元素的个数
for(int j=1;j<=m;++j){
if(!cnt[j]||j==a[i])
continue;
dp[1<<(j-1)][a[i]]+=cnt[j];//出现在a[i]以前的a[j]的个数(将a[i]原本的存放的颜色全部移动到a[j]原本存放的颜色以前所作出的贡献)
}
}
for(int i=0;i<1<<m;++i)
for(int j=1;j<=m;++j)
dp[i][j]=dp[i&(-i)][j]+dp[i^(i&(-i))][j];//将i中位上为1的颜色全部移动到到j颜色之前的贡献等于i去掉最后一位为1的序列的贡献加上i最后一位为1的贡献
memset(f,127/3,sizeof(f)),f[0]=0;
for(int i=0;i<1<<m;++i){
if(f[i]==f[1<<m])
continue;
for(int j=0;j<m;++j)
if(!(i>>j&1))//如果i向右移动j位是偶数(最后一位是0),说明中间有颜色没有移动到它应该的位置上
f[i|(1<<j)]=min(f[i]+dp[i][j+1],f[i|(1<<j)]);//将从右向左j位上的0补成1,它的贡献为自身和f[i]+dp[i][j+1]的最小值(i序列的贡献加上把i序列全部移动到j+1颜色以前的贡献)
}
cout<<f[(1<<m)-1]<<endl;//全部排列为1的贡献就是题意排列的答案
return 0;
}*/
Codeforces Round #585 (Div. 2)E(状态压缩DP,思维)的更多相关文章
- Codeforces Round #673 (Div. 2) C. k-Amazing Numbers (DP,思维)
题意:有一组数,分别用长度从\([1,n]\)的区间去取子数组,要求取到的所有子数组中必须有共同的数,如果满足条件数组共同的数中最小的数,否则输出\(-1\). 题解:我们先从后面确定每两个相同数之间 ...
- Codeforces C. A Simple Task(状态压缩dp)
题目描述: A Simple Task time limit per test 2 seconds memory limit per test 256 megabytes input standar ...
- Codeforces Round #521 (Div. 3) E. Thematic Contests(思维)
Codeforces Round #521 (Div. 3) E. Thematic Contests 题目传送门 题意: 现在有n个题目,每种题目有自己的类型要举办一次考试,考试的原则是每天只有一 ...
- Codeforces Round #174 (Div. 1) B. Cow Program(dp + 记忆化)
题目链接:http://codeforces.com/contest/283/problem/B 思路: dp[now][flag]表示现在在位置now,flag表示是接下来要做的步骤,然后根据题意记 ...
- Codeforces Round #241 (Div. 2) B. Art Union (DP)
题意:有\(n\)个画家,\(m\)幅画,每个画家负责\(m\)幅画,只有前一个画家画完时,后面一个画家才能接着画,一个画家画完某幅画的任务后,可以开始画下一幅画的任务,问每幅画最后一个任务完成时的时 ...
- B. The Number of Products(Codeforces Round #585 (Div. 2))
本题地址: https://codeforces.com/contest/1215/problem/B 本场比赛A题题解:https://www.cnblogs.com/liyexin/p/11535 ...
- Codeforces Round #585 (Div. 2) D. Ticket Game
链接: https://codeforces.com/contest/1215/problem/D 题意: Monocarp and Bicarp live in Berland, where eve ...
- Codeforces Round #585 (Div. 2) C. Swap Letters
链接: https://codeforces.com/contest/1215/problem/C 题意: Monocarp has got two strings s and t having eq ...
- Codeforces Round #585 (Div. 2) B. The Number of Products(DP)
链接: https://codeforces.com/contest/1215/problem/B 题意: You are given a sequence a1,a2,-,an consisting ...
随机推荐
- WEB前后端约定接口
- opencv:图形绘制与填充
#include <opencv2/opencv.hpp> #include <iostream> using namespace cv; using namespace st ...
- 解决新版Pycharm中Matplotlib图像不在弹出独立的显示窗口问题
官方说明链接: https://intellij-support.jetbrains.com/hc/en-us/community/posts/115000736584-SciView-in-PyCh ...
- java.lang.NoSuchMethodException: com.sun.tools.javac.util.List.<init>()
主要原因是import jar包的时候import java.util.List;这个,导致错误
- C++之void是什么?
void关键字的使用规则: 1. 如果函数没有返回值,那么应声明为void类型: 2. 如果函数无参数,那么应声明其参数为void: 3. 如果函数的参数可以是任意类型指针,那么应声明其参数为void ...
- IIS-简介
参考:https://www.jb51.net/article/85909.htm IIS是什么 iis是用来做什么的? IIS全程为Internet Information Service(In ...
- 学习笔记(23)- plato-准备中文语料
以plato使用的metalwoz数据集的INSURANCE为例,进行语料的汉化过程. 1. 下载数据集 微软的数据集,下载地址:https://www.microsoft.com/en-us/res ...
- 【C语言】输入5个整数并按输入顺序逆序输出
#include <stdio.h> int main() { ],i; printf("请输入5个整数:\n"); ;i<;i++) scanf("% ...
- java实现二维码的生成和解析:QRCode、zxing 两种方式
第一种:QRCode.jar,使用QRCode生成和解析二维码 1.导入jar包 2.代码 (1)QRCodeUtil .java import com.swetake.util.Qrcode; i ...
- iOS 开发之函数式编程思想(Functional Programming)
函数式编程(Functional Programming), 函数式编程强调的函数:1.不依赖外部状态:2.不改变外部状态. 函数式编程可解决线程安全问题,每一个函数都是线程安全的. 时间状态:变量一 ...