看了题解之后知道,是状压dp。

一、首先预处理一个$2^n$次方的fpow[]数组

fpow[]=;
for(Rint i=;i<=;i++)fpow[i]=(fpow[i-]<<);

二、然后预处理一个sta[i][j],表示经过O,i,j三点的那条抛物线经过的所有的点的状态,处理时要注意:

1、抛物线的$a$值大于等于0的要剔除

2、横坐标相同的两点不可能在同一条抛物线上

3、注意精度
处理完后就可以状压dp了。

三、dp时首先把dp[]值赋为inf

方程:

chkmin(dp[i|sta[J][K]],dp[i]+)

四、最后的优化:

1、就是我们没有必要枚举所有的$i$,其实不论如何,在$dp[i]$中第一个没有出现的猪,我们最后一定要打的,所以我们干脆就只枚举最后那个猪,这样可以快一点

2、找到第一只没打过的猪后,只需要枚举从它开始剩下的猪即可,不要从1开始:

for(Rint k=j+;k<=n;k++){//即此循环只需从j+1开始,而不需从1枚举到n
  int J=min(j,k),K=max(j,k);
  chkmin(dp[i|sta[J][K]],dp[i]+);
}

五、Attention!(洛谷AC,UOJ WA)

假如得了97分的话,估计是精度问题

判断a的正负时要if(a<-1e-6)

判断是否是同一解要if(Abs(...)<=1e-12)

否则会炸extra test

六、最后上AC代码:

#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
#define Rint register int
#define mem(a,b) memset(a,(b),sizeof(a))
using namespace std;
template<typename T>
inline void read(T &x){
x=;T w=,ch=getchar();
while(!isdigit(ch)&&ch!='-')ch=getchar();
if(ch=='-')w=-,ch=getchar();
while(isdigit(ch))x=(x<<)+(x<<)+(ch^''),ch=getchar();
x=x*w;
}
template<typename T>
inline T Min(T &x,T &y){return x<y?x:y;}
template<typename T>
inline void chkmin(T &x,T y){if(y<x)x=y;}
inline double Abs(double x){return x<?-x:x;} const int maxn=,inf=0x3f3f3f3f;
const double eps=1e-,eeps=-1e-;
int fpow[];
int n,m,sta[maxn][maxn],dp[<<maxn];
double x[maxn],y[maxn];
inline void init(){
n=;
m=;
}
inline void update_sta(int a,int b){
sta[a][b]=;
double x1=x[a],y1=y[a],x2=x[b],y2=y[b];
if(x1==x2)return;
double A=(y1*x2-y2*x1)/(x1*x1*x2-x2*x2*x1);
if(A>=eeps)return;
double B=(y1-A*x1*x1)/x1;
for(Rint i=;i<=n;i++)
if(Abs(A*x[i]*x[i]+B*x[i]-y[i])<eps)
sta[a][b]|=fpow[i-];
}
int main(){
fpow[]=;
for(Rint i=;i<=;i++)fpow[i]=(fpow[i-]<<);
int TT;
read(TT);
while(TT--){
init();
read(n);read(m);
for(Rint i=;i<=n;i++)scanf("%lf%lf",&x[i],&y[i]);
for(Rint i=;i<=n;i++)
for(Rint j=i+;j<=n;j++)
update_sta(i,j);
for(Rint i=;i<fpow[n];i++)dp[i]=inf;
dp[]=;
for(Rint i=;i<fpow[n];i++){
if(dp[i]==inf)continue;
for(Rint j=;j<=n;j++){
if(!(i&fpow[j-])){
for(Rint k=j+;k<=n;k++){
int J=min(j,k),K=max(j,k);
chkmin(dp[i|sta[J][K]],dp[i]+);
}
chkmin(dp[i|fpow[j-]],dp[i]+);
break;
}
}
}
printf("%d\n",dp[fpow[n]-]);
}
return ;
}

AC代码

NOIP2016 D2-T3 愤怒的小鸟的更多相关文章

  1. NOIP2016 DAY2 T3 愤怒的小鸟

    传送门 题目描述 Kiana 最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于 (0,0)(0,0) 处,每次 Kiana 可以用它向第一象限发射一只红色的 ...

  2. [NOIP2016]愤怒的小鸟 D2 T3 状压DP

    [NOIP2016]愤怒的小鸟 D2 T3 Description Kiana最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于(0,0)处,每次Kiana可 ...

  3. [NOIP2015]运输计划 D2 T3 LCA+二分答案+差分数组

    [NOIP2015]运输计划 D2 T3 Description 公元2044年,人类进入了宇宙纪元. L国有n个星球,还有n-1条双向航道,每条航道建立在两个星球之间,这n-1条航道连通了L国的所有 ...

  4. [NOIP2016]愤怒的小鸟 D2 T3

    Description Kiana最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于(0,0)处,每次Kiana可以用它向第一象限发射一只红色的小鸟,小鸟们的 ...

  5. 【NOIP2016提高组】 Day2 T3 愤怒的小鸟

    题目传送门:https://www.luogu.org/problemnew/show/P2831 说个题外话:NOIP2014也有一道题叫做愤怒的小鸟. 这题自测时算错了eps,导致被卡了精度,从1 ...

  6. 【NOIP 2016】Day2 T3 愤怒的小鸟

    Problem Description \(Kiana\) 最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于 \((0,0)\) 处,每次 \(Kiana\ ...

  7. [NOIP2016 TG D2T3]愤怒的小鸟

    题目大意:有一架弹弓位于(0,0)处,每次可以用它向第一象限发射一只小鸟,飞行轨迹均为形如y=ax2+bxy=ax+bx2 y=ax2+bx的曲线,且必须满足a<0(即是下开口的) 平面的第一象 ...

  8. [NOIp2016提高组]愤怒的小鸟

    题目大意: 平面直角坐标系的第一象限有n(n<=18)个点,你可以每次给出一个形如y=ax^2+bx的函数把经过这条函数的点消掉,问消掉所有的点至少要多少函数? 思路: 枚举每两个点对,可以唯一 ...

  9. NOIP2016 DAY1 T3 换教室

    换教室 Description 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程.在可以选择的课程中,有2n节 课程安排在n个时间段上.在第i(1≤i≤n)个时间段上,两节内 ...

  10. 逛公园[NOIP2017 D2 T3](dp+spfa)

    题目描述 策策同学特别喜欢逛公园. 公园可以看成一张 \(N\)个点\(M\) 条边构成的有向图,且没有自环和重边.其中 1号点是公园的入口,N号点是公园的出口,每条边有一个非负权值,代表策策经过这条 ...

随机推荐

  1. Lodop代码设置打印机等信息后 设置预览可重选

    Lodop打印控件默认在代码里指定了打印.纸张.纸张方向.份数等信息,在预览的界面的设置里是无法重新选择的,默认是禁止重选的,如果重选会提示,例如:“打印方向”已由程序控制,无法改变!“纸张大小”已由 ...

  2. BZOJ4383 Pustynia(线段树+拓扑排序)

    线段树优化建图暴力拓扑排序即可.对于已确定的数,拓扑排序时dp,每个节点都尽量取最大值,如果仍与已确定值矛盾则无解.叶子连出的边表示大于号,其余边表示大于等于. #include<iostrea ...

  3. Leonardo's Notebook UVALive - 3641(置换)

    题意: 给出26个大写字母的置换B,问是否存在一个置换A,使得A2 = B 解析: 两个长度为n的相同循环相乘,1.当n为奇数时结果也是一个长度为n的循环:2. 当n为偶数时分裂为两个长度为n/2 ( ...

  4. 一个开启多个事务导致OptimisticLockException异常的问题

    异常信息:org.eclipse.persistence.exceptions.OptimisticLockException 对象在其他的事物中被修改,而造成这一个问题的原因是:同时开启了两个事务, ...

  5. HTML DOM setAttribute()、与createAttribute()

    setAttribute().与createAttribute() 都可以动态的为DOM 添加属性:但是用法却不一样: 1.setAttribute() setAttribute() 直接在DOM节点 ...

  6. BZOJ 4754 [JSOI2016]独特的树叶 | 树哈希判同构

    题目链接 这道题是一道判断无根树同构的模板题,判断同构主要的思路就是哈希. 一遇到哈希题,一百个人能有一百零一种哈希方式,这篇题解随便选用了一种--类似杨弋<Hash在信息学竞赛中的一类应用&g ...

  7. SharePoint 2013 Central Admin 不能打开

    当我准备打开CA时发现下面的错误: This operation can be performed only on a computer that is joined to a server farm ...

  8. 姿态角(Euler角):yaw pitch roll

    姿态角(Euler角):yaw pitch roll  

  9. bzoj4336 骑士的旅行 (树链剖分+multiset)

    首先大概有一个树剖+树套树的做法,但我哪会写啊 然后发现k很小,如果用线段树记每个区间前k大的的话,可以O(k)地合并 而且一个点还有可能有好多个骑士,所以要用multiset维护一下 然后树剖就好啦 ...

  10. EXGCD 扩展欧几里得

    推荐:https://www.zybuluo.com/samzhang/note/541890 扩展欧几里得,就是求出来ax+by=gcd(x,y)的x,y 为什么有解? 根据裴蜀定理,存在u,v使得 ...