状压DP之愤怒的小鸟
题目
传送们P2831
题目较长,不加以赘述
直接步入正题
首先是数学知识,我们可以先根据给出的任意两只猪构建相应的抛物线,同时再构建完之后应判断抛物线的合法性(比如a小于0啊,等等),公式推演就不在这里说了,这里需要注意的是对于浮点型判断,不能单纯用相等,这里我们可以定义一个十分小的数,将两数差值与其相比,一般用到数为\(1e-6\)就可了,根据两个两只猪得来的抛物线,将其他猪带入,求相应抛物线所能经过的所有猪的状态,与原状态求或,即\(num[i][j]|=(1<<(k-1))\),就是\(k\)在\(i\),\(j\)所在抛物线上时更新该抛物线状态;
处理完这个,我们可以来定义DP数组了,对于这道题,我们只需要一维数组就可了,定义\(F[i]\)数组代表打死\(i\)状态下猪的所需最少小鸟数,首先枚举状态,其次枚举两层猪的个数(用于枚举抛物线),为了避免重复,第二遍枚举我们从第一遍所在位置开始枚举,在这里我们可以稍稍进行一下优化,在进行第一遍枚举时,如果这只猪已经包含在当前状态内,我们可以直接跳过,因为当我们跳过后,第二遍枚举有两种情况,即第一种,第二遍枚举的猪也包含在当前状态下,这时候可以直接跳过,第二种,所枚举的猪并不在当前状态下,需要进行操作,但是第一层循环会重复操作,故在进行第一遍枚举时,如果这只猪已经包含在当前状态内,我们可以直接跳过,来进行一个优化;
然后是转移方程,分为两种情况
- \(i\)和\(j\)相等时,那么我们有\(f[i|(1<<(j-1))]=min(f[i|(1<<(j-1))],f[i]+1)\),这种情况下\(F[i][(1<<(j-1))]\)只需要转移上一状态,或者在当前状态下多射出一直小鸟;
- \(i\)和\(j\)不相等时,\(f[i|num[j][k]]=min(f[i|num[j][k]],f[i]+1)\),解释同上;
还有一点,
因为本道题是多组测试数据,记得初始化
接下来是代码
#include<bits/stdc++.h>
using namespace std;
int T,n,m,num[20][20],f[1000000];
double x[20],y[20];
bool same(double x,double y){return fabs(x-y)<1e-6;}//判断相等与否的函数
int main(){
scanf("%d",&T);
while(T--){
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)scanf("%lf%lf",&x[i],&y[i]);
memset(num,0,sizeof(num));//num数组初始化
for(int i=1;i<=n;i++){//第一遍枚举猪
for(int j=i+1;j<=n;j++){//第二遍枚举猪
if(same(x[i],x[j]))continue;//x[i]=x[j]无法构成抛物线
double a=(y[j]/x[j]-y[i]/x[i])/(x[j]-x[i]);//公式推导
if(a>0)continue;//a>0不合法抛物线,跳过
double b=y[i]/x[i]-a*x[i];//公式推导
for(int k=1;k<=n;k++){//枚举猪,判断其他猪是不是可以在该抛物线上
if(same(a*x[k]+b,y[k]/x[k]))num[i][j]|=(1<<(k-1));//如果可以,更新
}
}
}
memset(f,0x3f3f3f3f,sizeof(f));//初始化f数组
f[0]=0;//打死0这个状态下的猪需要小鸟0只
for(int i=0;i<=(1<<n)-1;i++){//枚举状态
for(int j=1;j<=n;j++){//第一层枚举猪
if(!(i&(1<<(j-1)))){//优化(具体见上)
for(int k=j;k<=n;k++){//第二层枚举猪
if(j==k)f[i|(1<<(j-1))]=min(f[i|(1<<(j-1))],f[i]+1);//j=k的转移情况
f[i|num[j][k]]=min(f[i|num[j][k]],f[i]+1);//j!=k的转移情况
}
}
}
}
printf("%d\n",f[(1<<n)-1]);//输出打死(1<<n)-1(即所有猪)状态下猪所需要的小鸟数
}
}
状压DP之愤怒的小鸟的更多相关文章
- [NOIP2016]愤怒的小鸟 D2 T3 状压DP
[NOIP2016]愤怒的小鸟 D2 T3 Description Kiana最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于(0,0)处,每次Kiana可 ...
- NOIP2016愤怒的小鸟 [状压dp]
愤怒的小鸟 题目描述 Kiana 最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于 (0,0) 处,每次 Kiana 可以用它向第一象限发射一只红色的小鸟, ...
- [Luogu P2831] 愤怒的小鸟 (状压DP)
题面: 传送门:https://www.luogu.org/problemnew/show/P2831 Solution 首先,我们可以先康一康题目的数据范围:n<=18,应该是状压或者是搜索. ...
- Noip2016愤怒的小鸟(状压DP)
题目描述 题意大概就是坐标系上第一象限上有N只猪,每次可以构造一条经过原点且开口向下的抛物线,抛物线可能会经过某一或某些猪,求使所有猪被至少经过一次的抛物线最少数量. 原题中还有一个特殊指令M,对于正 ...
- luogu2831 [NOIp2016]愤怒的小鸟 (状压dp)
由范围可以想到状压dp 两个点(再加上原点)是可以确定一个抛物线的,除非它们解出来a>=0,在本题中是不合法的 这样的话,我们可以预处理出由任意两个点确定的抛物线所经过的所有的点(要特别规定一下 ...
- NOIP2016愤怒的小鸟 题解报告 【状压DP】
题目什么大家都清楚 题解 我们知道,三点确定一条抛物线,现在这条抛物线过原点,所以任意两只猪确定一条抛物线.通过运算的出对于两头猪(x1,y1),(x2,y2),他们所在抛物线a=(y1*x2-y2* ...
- 洛谷P2831 愤怒的小鸟(状压dp)
题意 题目链接 Sol 这题....我样例没过就A了??..算了,就当是样例卡精度吧.. 直接状压dp一下,\(f[sta]\)表示干掉\(sta\)这个集合里面的鸟的最小操作数 转移的时候判断一下一 ...
- [Noip2016]愤怒的小鸟(状压DP)
题目描述 题意大概就是坐标系上第一象限上有N只猪,每次可以构造一条经过原点且开口向下的抛物线,抛物线可能会经过某一或某些猪,求使所有猪被至少经过一次的抛物线最少数量. 原题中还有一个特殊指令M,对于正 ...
- 【NOIP2016】愤怒的小鸟(状压DP)
题意: Kiana最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于(0,0)处,每次Kiana可以用它向第一象限发射一只红色的小鸟,小鸟们的飞行轨迹均为形如 ...
随机推荐
- java实现第六届蓝桥杯熊怪吃核桃
熊怪吃核桃 题目描述 森林里有一只熊怪,很爱吃核桃.不过它有个习惯,每次都把找到的核桃分成相等的两份,吃掉一份,留一份.如果不能等分,熊怪就会扔掉一个核桃再分.第二天再继续这个过程,直到最后剩一个核桃 ...
- Linux 自动挂载与fstab文件修复
/etc/fstab文件 自动挂载就是写入/etc/fstab文件 vi /etc/fstab 其中,第九行是/分区的自动挂载信息,有6个字段 第一字段表示分区的UUID(硬盘通用唯一识别码,使用du ...
- 性能测试中TPS上不去的原因
TPS(Transaction Per Second):每秒事务数,指服务器在单位时间内(秒)可以处理的事务数量,一般以request/second为单位. 压测中为什么TPS上不去的原因: .网络带 ...
- requireJS模块化
1. JavaScript里面js代码的写法:目标是解决冲突和依赖 函数式编程,全局函数和变量--很容易覆盖 对象的写法--也会从外面改变 命名空间:利用名称不同缓冲js代码的冲突---名称太长,不方 ...
- 用云开发Cloudbase,实现小程序多图片内容安全监测
前言 相比于文本的安全检测,图片的安全检测要稍微略复杂一些,当您读完本篇,将get到 图片安全检测的应用场景 解决图片的安全校验的方式 使用云调用方式对图片进行检测 如何对上传图片大小进行限制 如何解 ...
- 读懂操作系统之缓存原理(cache)(三)
前言 本节内容计划是讲解TLB与高速缓存的关系,但是在涉及高速缓的前提是我们必须要了解操作系统缓存原理,所以提前先详细了解下缓存原理,我们依然是采取循序渐进的方式来解答缓存原理,若有叙述不当之处,还请 ...
- Windows学习Nodejs、Npm和VUE
前言 本文主要以开发的角度讲解Node.js,Npm和Vue. Node.js学习 什么是Node.js Node.js简单来说就是一个IISExpress,提供一个前端Html的独立运行环境. 安装 ...
- Jackson乱码问题
在配置文件中加入下面的内容 <!-- Json乱码问题配置--> <mvc:annotation-driven> <mvc:message-converters regi ...
- flutter-web利用dart js 库发起http request
初学flutter,初学前端,尝试在dart中直接使用HttpClient时,直接报出Platform not supported,查资料发现他还不支持浏览器. 通过查阅资料发现可以借助axios 与 ...
- CentOS7.5搭建Hadoop2.7.6完全分布式集群
一 完全分布式集群搭建 Hadoop官方地址:http://hadoop.apache.org/ 1 准备3台客户机 1.2 关闭防火墙,设置静态IP,主机名 关闭防火墙,设置静态IP,主机名此处略 ...