严厉的班长

描述

木姑娘在班级里面是班长。虽然是副班长,却有着比正班长更高的威信,并深受小朋友们的爱戴。

每天眼保健操时间,木姑娘都要监督所有小朋友认真做眼保健操。整个过程被描述为n个时间段,第i个时间段内对于揉捏穴位的速度被要求为a[i]。

如果某一位小朋友在n个时间段内,速度分别为b[1],b[2],...,b[n],则他的最终得分为 score = |a[1]-b[1]| + |a[2]-b[2]| + ... + |a[n]-b[n]|。

分数越大,则说明表现越差,如果b[1]到b[n]中,又满足任意两个数字均互素,则会受到木姑娘的严厉批评。

对于爱慕木姑娘的孩子来说,能和木姑娘有更多时间待在一起,才是最关键的。

格式

输入格式

第一行一个整数n,1<=n<=100。

第二行有n个整数,分别为a[1],a[2],...,a[n]且对于每一个a[i]满足1<=a[i]<=30。

输出格式

希望可以找出来一组b[1],...,b[n]满足score最小化,且b数组中的n个元素两两互素,并输出此刻的分数score。

样例1

样例输入1

5
1 1 1 1 1

样例输出1

0

样例2

样例输入2

5
1 6 4 2 8

样例输出2

3

限制

25%的数据,n<=10。
60%的数据,n<=30。
100%的数据,n<=100。

来源

感谢 小岛

题目链接:

  https://www.vijos.org/p/1921

题目大意:

  题目给一个N个数的数列Ai,数大小不超过30,要求给出一组解Xi,使得解Xi Xj两两互质的情况下和原先数列的绝对值的差的和最小(min Σ|Ai-Xi|),求这个和。

题目思路:

  【状压DP】

  首先考虑,因为要求两两互质,所以1肯定满足,那么取1<=Xi<2Ai-1(取2Ai-1和取1效果相同且更不易满足互质条件)

  然后看2x30-1=59以内的质数,2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53 共16个。

  也就是说当n>16时,多出来的必须用1,那么考虑数的大小可知尽量用1取对应小的数,于是排序的时候按从大到小排序,只做前16个,后面的全是1(当然前面也可以用1而不用质数)

  所以问题转化为用16个质数的倍数去满足前16个数即可。将1~59质因数分解,记下每个数含有的质因数的二进制码,例如1为0,2为1,3为10,4为1,5为100,6为11 以此类推

  DP的时候f[i][j]表示前i个数,质因数已经被选走的状态为j的最小和(j为16位二进制数)

  考虑当前状态如果可行,就枚举当前的Xi,判断是否冲突,不冲突就更新新的f

  

 /****************************************************

     Author : Coolxxx
Copyright 2017 by Coolxxx. All rights reserved.
BLOG : http://blog.csdn.net/u010568270 ****************************************************/
#include<bits/stdc++.h>
#pragma comment(linker,"/STACK:1024000000,1024000000")
#define abs(a) ((a)>0?(a):(-(a)))
#define lowbit(a) (a&(-a))
#define sqr(a) ((a)*(a))
#define mem(a,b) memset(a,b,sizeof(a))
const double EPS=0.00001;
const int J=;
const int MOD=;
const int MAX=0x7f7f7f7f;
const double PI=3.14159265358979323;
const int N=;
const int M=;
using namespace std;
typedef long long LL;
double anss;
LL aans;
int cas,cass;
int n,m,lll,ans;
int p[]={,,,,,,,,,,,,,,,};
int a[N],fj[N];
int f[N][M];
void init()
{
int i,j,x;
for(i=;i<;i++)
{
x=i;
fj[i]=;
for(j=;j<;j++)
{
while(x%p[j]==)
{
x/=p[j];
fj[i]|=(<<j);
}
if(x==)break;
}
}
}
int main()
{
#ifndef ONLINE_JUDGE
// freopen("1.txt","r",stdin);
// freopen("2.txt","w",stdout);
#endif
int i,j,k;
int x,y,z;
// for(scanf("%d",&cass);cass;cass--)
// for(scanf("%d",&cas),cass=1;cass<=cas;cass++)
init();
while(~scanf("%d",&n))
{
mem(f,0x7f);
for(i=;i<=n;i++)
scanf("%d",&a[i]);
sort(a+,a++n,greater<int>());
f[][]=;
for(i=;i<=min(n,);i++)
{
for(j=;j<(<<);j++)
{
if(f[i-][j]==MAX)continue;
for(k=;k<=a[i]+a[i]-;k++)
{
if(fj[k] & j)continue;
f[i][j|fj[k]]=min(f[i][j|fj[k]],f[i-][j]+abs(a[i]-k));
}
}
}
ans=MAX;
for(i=;i<(<<);i++)
ans=min(ans,f[min(n,)][i]);
if(n>)
{
for(i=;i<=n;i++)
ans+=a[i]-;
}
printf("%d\n",ans);
}
return ;
}
/*
// //
*/

Vijos 1921 严厉的班长 【状态压缩动态规划】的更多相关文章

  1. BZOJ_4197_[Noi2015]寿司晚宴_状态压缩动态规划

    BZOJ_4197_[Noi2015]寿司晚宴_状态压缩动态规划 Description 为了庆祝 NOI 的成功开幕,主办方为大家准备了一场寿司晚宴.小 G 和小 W 作为参加 NOI 的选手,也被 ...

  2. 状态压缩动态规划 状压DP

    总述 状态压缩动态规划,就是我们俗称的状压DP,是利用计算机二进制的性质来描述状态的一种DP方式 很多棋盘问题都运用到了状压,同时,状压也很经常和BFS及DP连用,例题里会给出介绍 有了状态,DP就比 ...

  3. 状态压缩动态规划(状压DP)详解

    0 引子 不要999,也不要888,只要288,只要288,状压DP带回家.你买不了上当,买不了欺骗.它可以当搜索,也可以卡常数,还可以装B,方式多样,随心搭配,自由多变,一定符合你的口味! 在计算机 ...

  4. poj 3254(状态压缩+动态规划)

    http://poj.org/problem?id=3254 题意:有一个n*m的农场(01矩阵),其中1表示种了草可以放牛,0表示没种草不能放牛,并且如果某个地方放了牛,它的上下左右四个方向都不能放 ...

  5. 【学术篇】状态压缩动态规划——POJ3254/洛谷1879 玉米田Corn Field

    我要开状压dp的坑了..直播从入门到放弃系列.. 那就先拿一道状压dp的水题练练手吧.. 然后就找到了这一道..这道题使我清醒地认识到阻碍我的不是算法,而是视力= = 传送门: poj:http:// ...

  6. BZOJ1087 [SCOI2005]互不侵犯King 状态压缩动态规划

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1087 题意概括 在n*n的棋盘上面放k个国王,使得他们互相无法攻击,问有多少种摆法. 题解 dp[ ...

  7. BZOJ1076 [SCOI2008]奖励关 概率 状态压缩动态规划

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1076 题意概括 有n个东西,k次扔出来.每次等概率扔出其中一个. 你可以拿这个东西,但是有条件,得 ...

  8. YBT 5.4 状态压缩动态规划

    #loj 10170. 「一本通 5.4 例 1」骑士 看数据范围n<=10,所以不是搜索就是状压dp,又因为搜索会超时所以用dp dp[i][k][j]表示现已经放到第i行,前面共有k个,这一 ...

  9. CODEVS_2800 送外卖 状态压缩+动态规划

    原题链接:http://codevs.cn/problem/2800/ 题目描述 Description 有一个送外卖的,他手上有n份订单,他要把n份东西,分别送达n个不同的客户的手上.n个不同的客户 ...

随机推荐

  1. POJ 3581 Sequence ——后缀数组 最小表示法

    [题目分析] 一见到题目,就有了一个显而易见obviously的想法.只需要每次找到倒过来最小的那一个字符串翻转就可以了. 然而事情并不是这样的,比如说505023这样一个字符串,如果翻转了成为320 ...

  2. BZOJ4446 [Scoi2015]小凸玩密室 【树形Dp】

    题目 小凸和小方相约玩密室逃脱,这个密室是一棵有n个节点的完全二叉树,每个节点有一个灯泡.点亮所有灯 泡即可逃出密室.每个灯泡有个权值Ai,每条边也有个权值bi.点亮第1个灯泡不需要花费,之后每点亮4 ...

  3. Hibernate批量更新和批量删除批量添加(转)

    通常,在一个Session对象的缓存中只存放数量有限的持久化对象,等到Session对象处理事务完毕,还要关闭Session对象,从而及时释放Session的缓存占用的内存.批量处理数据是指在一个事务 ...

  4. bzoj1853: [Scoi2010]幸运数字 dp+容斥原理

    在中国,很多人都把6和8视为是幸运数字!lxhgww也这样认为,于是他定义自己的“幸运号码”是十进制表示中只包含数字6和8的那些号码,比如68,666,888都是“幸运号码”!但是这种“幸运号码”总是 ...

  5. hdu 1104 数论+bfs

    Remainder Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total ...

  6. .net面试题汇总-第二篇

    本篇主要关注下,.net面试题中经常用的算法问题 1.有一群猴子,它们每天要吃桃子,它们第一天吃的数量是总量的一半再多一个,第二天吃的是第一天剩下的一半再多一个,第三天吃的是第二天剩下的一半多一个,以 ...

  7. P1339 热浪Heat Wave 洛谷

    https://www.luogu.org/problem/show?pid=1339 题目描述 The good folks in Texas are having a heatwave this ...

  8. Maven的仓库

    以下内容引用自https://ayayui.gitbooks.io/tutorialspoint-maven/content/book/maven_repositories.html: 什么是Mave ...

  9. [vxlan] 二 什么是VXLAN

    VXLAN是一种mac in UDP的技术.简单讲就是传统的二层帧被封装到了UDP的package中.通过UDP的IP网络发送到目的地然后再解封装. VXLAN 跟VLAN对比,最重要的一个概念就是V ...

  10. 微信小程序 - 音频播放(1.2版本和1.2版本之后)

    不多说了,直接贴code // 1.2版本以后便不在维护 wx.getBackgroundAudioManager({ success:function(res){ var status =res.s ...