#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,思维)的更多相关文章

  1. Codeforces Round #673 (Div. 2) C. k-Amazing Numbers (DP,思维)

    题意:有一组数,分别用长度从\([1,n]\)的区间去取子数组,要求取到的所有子数组中必须有共同的数,如果满足条件数组共同的数中最小的数,否则输出\(-1\). 题解:我们先从后面确定每两个相同数之间 ...

  2. Codeforces C. A Simple Task(状态压缩dp)

    题目描述:  A Simple Task time limit per test 2 seconds memory limit per test 256 megabytes input standar ...

  3. Codeforces Round #521 (Div. 3) E. Thematic Contests(思维)

    Codeforces Round #521 (Div. 3)  E. Thematic Contests 题目传送门 题意: 现在有n个题目,每种题目有自己的类型要举办一次考试,考试的原则是每天只有一 ...

  4. Codeforces Round #174 (Div. 1) B. Cow Program(dp + 记忆化)

    题目链接:http://codeforces.com/contest/283/problem/B 思路: dp[now][flag]表示现在在位置now,flag表示是接下来要做的步骤,然后根据题意记 ...

  5. Codeforces Round #241 (Div. 2) B. Art Union (DP)

    题意:有\(n\)个画家,\(m\)幅画,每个画家负责\(m\)幅画,只有前一个画家画完时,后面一个画家才能接着画,一个画家画完某幅画的任务后,可以开始画下一幅画的任务,问每幅画最后一个任务完成时的时 ...

  6. 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 ...

  7. Codeforces Round #585 (Div. 2) D. Ticket Game

    链接: https://codeforces.com/contest/1215/problem/D 题意: Monocarp and Bicarp live in Berland, where eve ...

  8. 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 ...

  9. 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 ...

随机推荐

  1. 项目中报错:Unsupported major.minor version

    在开发中或多或少都会遇到如下报错: java.lang.UnsupportedClassVersionError: com/xie/IntegerTest : Unsupported major.mi ...

  2. LoadRunner通过火狐浏览器录制脚本后,进行回放时,回放脚本很慢

    原因:火狐浏览器在录制的时候,录制了下载插件的脚本 解决办法:在脚本中删除额外资源中的下载代码

  3. 吴裕雄--天生自然神经网络与深度学习实战Python+Keras+TensorFlow:Bellman函数、贪心算法与增强性学习网络开发实践

    !pip install gym import random import numpy as np import matplotlib.pyplot as plt from keras.layers ...

  4. 在ubuntu永久添加alias

    1. cd 进入家目录 操作如下: cd ~ 2.显示隐藏文件 操作如下:ls -al 3.vim打开.bashrc 操作如下: vim .bashrc 4.按a编辑添加alias example=' ...

  5. Python socket day3

    UDP聊天室 本地回环(127.0.0.1) 本地回环是每台电脑都有的,只能用于自身电脑的通讯,无论你的IP地址是多少,只要发送方输入的目的IP为127.0.0.1 ,自身便能接受得到数据 测试本地回 ...

  6. 关于 checkbox 的一些操作

    获取checkbox选中的状态 $("#checkbox").is(":checked"); 设置 checkbox 的状态 $("#checkbox ...

  7. P3378 (模板)并查集

    使用带路径压缩的并查集,不然会TLE AC代码: #include <bits/stdc++.h> #define MP make_pair #define PB push_back #d ...

  8. NAT穿透的详细讲解及分析

    原文地址:http://bbs.pediy.com/thread-131961.htm 一.什么是NAT?为什么要使用NAT?NAT是将私有地址转换为合法IP地址的技术,通俗的讲就是将内网与内网通信时 ...

  9. CSS-自适应网页使用@media和rem

    @media 查询 @media 媒体查询选择性加载css,意思是自动探测屏幕宽度,然后加载相应的CSS文件.可以针对不同的屏幕尺寸设置不同的样式,特别是需要设置设计响应式的页面,@media 是个不 ...

  10. 带你了解MyBatis一二级缓存

    在对数据库进行噼里啪啦的查询时,可能存在多次使用相同的SQL语句去查询数据库,并且结果可能还一样,这时,如果不采取一些措施,每次都从数据库查询,会造成一定资源的浪费,所以Mybatis中提供了一级缓存 ...