P2831 愤怒的小鸟(状压dp)
我们先预处理出每个猪两两之间(设为$u,v$)和原点三点确定的抛物线(当两只猪横坐标相等时显然无解)
处理出$u,v$确定的抛物线一共可以经过多少点,记为$lines[u][v]$
设$f[i]$表示已经被消灭的猪的集合为二进制表示为$i$时,需要的最小抛物线数
显然$f[0]=0$
$f[i|(1<<(u-1))]=min(f[i|(1<<(u-1)],f[i]+1)$(一条抛物线只串一个点)
$f[i|lines[u][v]]=min(f[i|lines[u][v]],f[i]+1)$
然鹅这是$O(Tn^{2}2^{n})$,ccf的老爷机会T
那么我们考虑优化
我们发现加上抛物线时,先串$1,4$与先串$2,3$没有区别,但是我们两种都用不同的顺序枚举了一遍。
那么我们可以处理出集合$i$的$mex$(在集合中没有出现的最小正整数)
枚举时加上限制条件:一定要包含$mex[i]$
于是枚举就从$O(n^{2})$降到了$O(n)$
总复杂度就降到了$O(Tn2^{n})$
end.
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#define re register
using namespace std;
typedef double db;
int min(int &a,int &b){return a<b?a:b;}
#define N 524589
const db eps=1e-;
db x[],y[];
int t,n,m,lines[][],f[N],mex[N];
void calc(db &a,db &b,db x1,db y1,db x2,db y2){
b=(x1*x1*y2-x2*x2*y1)/(x1*x1*x2-x1*x2*x2);
a=(y1-x1*b)/(x1*x1);
}//用于解一元二次方程组
int main(){
for(re int i=,j;i<;++i){//预处理mex
for(j=;(i&(<<j))&&j<;++j);
mex[i]=j;
}scanf("%d",&t);
while(t--){
scanf("%d%d",&n,&m); db a,b;
for(re int i=;i<=n;++i)
scanf("%lf%lf",&x[i],&y[i]);
for(re int i=;i<=n;++i)
for(re int j=;j<=n;++j){
lines[i][j]=;
if(fabs(x[i]-x[j])<eps) continue;//横坐标相等无解
calc(a,b,x[i],y[i],x[j],y[j]);
if(a>-eps) continue;
for(re int u=;u<=n;++u)
if(fabs(a*x[u]*x[u]+b*x[u]-y[u])<eps)
lines[i][j]|=(<<(u-));//找到这条抛物线能连到的所有点
}
memset(f,,sizeof(f)); f[]=;
for(re int i=,j=mex[i];i<(<<n);j=mex[++i]){
f[i|(<<j)]=min(f[i|(<<j)],f[i]+); //单个点用掉一条的情况
for(re int u=;u<=n;++u)//枚举的抛物线必须穿过j
f[i|lines[j+][u]]=min(f[i|lines[j+][u]],f[i]+);
}
printf("%d\n",f[(<<n)-]);
}return ;
}
P2831 愤怒的小鸟(状压dp)的更多相关文章
- [Luogu P2831] 愤怒的小鸟 (状压DP)
题面: 传送门:https://www.luogu.org/problemnew/show/P2831 Solution 首先,我们可以先康一康题目的数据范围:n<=18,应该是状压或者是搜索. ...
- 洛谷P2831 愤怒的小鸟(状压dp)
题意 题目链接 Sol 这题....我样例没过就A了??..算了,就当是样例卡精度吧.. 直接状压dp一下,\(f[sta]\)表示干掉\(sta\)这个集合里面的鸟的最小操作数 转移的时候判断一下一 ...
- 【题解】P2831 愤怒的小鸟 - 状压dp
P2831愤怒的小鸟 题目描述 \(Kiana\) 最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于 \((0,0)\) 处,每次 \(Kiana\) 可以 ...
- P2831 愤怒的小鸟 状压dp
这个题主要是预处理比较复杂,先枚举打每只鸟用的抛物线,然后找是否有一个抛物线经过两只鸟,然后就没了. 题干: 题目描述 Kiana 最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上 ...
- NOIP2016愤怒的小鸟 [状压dp]
愤怒的小鸟 题目描述 Kiana 最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于 (0,0) 处,每次 Kiana 可以用它向第一象限发射一只红色的小鸟, ...
- luogu2831 [NOIp2016]愤怒的小鸟 (状压dp)
由范围可以想到状压dp 两个点(再加上原点)是可以确定一个抛物线的,除非它们解出来a>=0,在本题中是不合法的 这样的话,我们可以预处理出由任意两个点确定的抛物线所经过的所有的点(要特别规定一下 ...
- [noip2016]愤怒的小鸟<状压dp+暴搜>
题目链接:https://vijos.org/p/2008 现在回过头去看去年的考试题,发现都不是太难,至少每道题都有头绪了... 这道题的数据范围是18,这么小,直接暴力呗,跑个暴搜就完了,时间也就 ...
- NOIP2016Day2T3愤怒的小鸟(状压dp) O(2^n*n^2)再优化
看这范围都知道是状压吧... 题目大意就不说了嘿嘿嘿 网上流传的写法复杂度大都是O(2^n*n^2),这个复杂度虽然官方数据可以过,但是在洛谷上会TLE[百度搜出来前几个博客的代码交上去都TLE了], ...
- P2831 愤怒的小鸟——状压
P2831 愤怒的小鸟 抛物线过原点,只要再找两个就能确定抛物线: 处理出两两之间的抛物线能过哪些点,状态压缩: 但是直接枚举每一条抛物线常数太大会T,所以我们需要预处理一个low_bit表示当前状态 ...
- Luogu P2831 愤怒的小鸟(状压+记忆化搜索)
P2831 愤怒的小鸟 题意 题目描述 Kiana最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于\((0,0)\)处,每次Kiana可以用它向第一象限发射 ...
随机推荐
- php实现注册审核功能
本章主要实现注册之后审核通过的功能,共这几部分组成: 1. 创建数据库:mydb数据库的user表 注:isok判断是否通过审核,1为通过,0为未通过. 显示效果: 2.首先做注册界面:zhuce ...
- thinkphp5 邮件发送(qq邮箱为例)
一.首先需要你开启smtp 服务,登录qq邮箱,进入设置 -> 账户 注意: 开启后会生成授权码,一定要记下,两个都记下,登录邮件客户端需要.这里配置邮件发送也需要这个授权码 二. 下载phpm ...
- bzoj 3307 雨天的尾巴
题目链接:传送门 题目大意:中文题,略 题目思路:网上有题解说是合并线段树的,但是太难蒟蒻不会,只能用树剖求解 如果不是树而是一维数组我们会怎么解? 当然是利用前缀和思想标记 (L) v+1,(R+1 ...
- 【node】----mocha单元测试框架-----【巷子】
1.mocha简介 单元测试是用来对一个模块.一个函数.或者一个类来进行正确性的检测工作 特点: 既可以测试简单的JavaScript函数,又可以测试异步代码, 可以 ...
- lnmp一键安装环境添加redis扩展及作为mysql的缓存
lnmp一键安装环境添加redis扩展 Redis-benchmark 压力测试工具Redis-check-aof 检查redis持久化命令文件的完整性Redis-check-du ...
- 170808、生成为CVS文件
/** * Desc : 生成为CVS文件 * User : RICK * @param data 源数据List * @param map csv文件的列表头map * @param outPutP ...
- codeforces #516---ABC
A---golden plate http://codeforces.com/contest/1072/problem/A 题意:给一个n*m的格子,从最外层往里涂色,每次尽量涂最外面的那一圈,两圈涂 ...
- linux设备驱动开发详解 笔记
在目录的 Makefile 中关于 RTC_DRV_S3C 的编译脚本为: obj -$(CONFIG_RTC_DRV_S3C) += rtc-s3c.o 上述脚本意味着如果 RTC_DRV_S3 ...
- 7.1 - CRM系统
一.简介 crm 客户关系管理软件 ( Customer Relationship Management ) ( 详细内容 ) stark组件(仿admin组件)( 详细内容 ) rbac组件(基于角 ...
- The Accomodation of Students---hdu2444(二分图,最大匹配)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2444 题意:有n个学生,m个关系,但是如果a认识b,b认识c,但是a不一定认识c: 求能不能把这n个人 ...