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 ...
随机推荐
- Linux - 常用Shell软件
tldr conda dstat htop oh-my-zsh https://github.com/nicolargo/glances neofetch
- oracle关于sequence的个人理解
oracle关于sequence的个人理解 1. sequence在多用户使用时的同步问题 个人感觉sequence是以连接(会话)为基础,类似于java中使用mysql的一个connection 网 ...
- qq音乐解析API
文档:www.tjit.net 开放的接口:api88.net 个人代码: input2(event){ //将字符转化为encodeURL编码,才能进行正确请求,这是这个接口要求的 //js自带的转 ...
- github是什么,有什么用
转载连接:https://blog.csdn.net/obkoro1/article/details/68066441 写在前面:关于github的文章我已经写了两篇了,关于github个人网站搭建和 ...
- Go语言内置包之strconv
文章引用自 Go语言内置包之strconv Go语言中strconv包实现了基本数据类型和其字符串表示的相互转换. strconv包 strconv包实现了基本数据类型与其字符串表示的转换,主要有以下 ...
- 【JavaScript基础#2】
" 目录 #. 函数 1. 定义 2. arguments 参数 3. 全局变量与局部变量 4. 语法分析 #. 内置对象和方法 1. 自定义对象 2. 类之继承 3. Date 4. JS ...
- 将训练好的Tensorflow模型部署到web应用中
做一个简易web使用Flask是最好的选择,不仅上手快,使用也很便利.Django很强大也很好用,但一次就会创建一个项目的所需的文件,我觉得对于测试一个模型在web端有没有效果没必要用它. flask ...
- tp5 配置 // 视图输出字符串内容替换 'view_replace_str' 的原理
- mysql-8.0.18-winx64 环境变量的配置
1. 鼠标右击 此电脑 -->属性 如图:进行步骤 1->2->3 接下来就可以使用命令mysql -u root -p登录mysql了 启动mysql的命令为net ...
- ASP.NET Core搭建多层网站架构【14-扩展之部署到IIS】
2020/02/03, ASP.NET Core 3.1, VS2019, IIS 10, dotnet-hosting-3.1.1-win.exe 摘要:基于ASP.NET Core 3.1 Web ...