日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

题解 P2831 【愤怒的小鸟】

發(fā)布時間:2024/10/8 编程问答 37 如意码农
生活随笔 收集整理的這篇文章主要介紹了 题解 P2831 【愤怒的小鸟】 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

題目

我的天,這題是真的卡精度......

主要是精度很不好處理,經(jīng)本蒟蒻測驗,精度在\(10^{-6}\)會比較好優(yōu)雅


【分析】

對于這種某個變量特別小\((\leq 31)\)的題目,本蒟蒻第一反應就是狀壓

對于某個拋物線,一定要打到起碼一個小豬(不然不如不要這一條拋物線)

有人覺得最少會打掉兩只小豬的,可以仔細想一下,萬一\(a \geq 0\)呢......

好的,我們繼續(xù)

那么,我們可以這么考慮,枚舉每一只小豬的坐標

首先,有一條拋物線是只過它的

其次,再枚舉其他小豬,算出拋物線方程(見下方),若\(a<0\)就記錄這條拋物線,否則可以直接跳出

記錄完這條拋物線后,我們枚舉其他的小豬,查看是否在線上

這里要注意精度問題,如果計算出來的\(y\)與題目所給的\(y\)偏差值不超過\(10^{-6}\),就直接視為同一個值(畢竟計算是有一定的精度問題)

那么對于接下來,我已經(jīng)預處理過了所有的小鳥的軌跡(拋物線),只需要在狀壓方程中直接算就可以了

在打\(0\)只小豬的時候,需要用\(0\)只小鳥,于是有:

\(dp[0]=0\)

假設當前狀態(tài)為\(i\),拋物線為第\(j\)條,拋物線打掉的小豬狀態(tài)為\(para[j]\),那么有:

\(dp[i|para[j]]=min(dp[i|para[j]],dp[i]+1)\)


接下來我們說一下怎么求\(a\)和\(b\):

假設枚舉到兩個小豬,坐標分別為\((x_1,y_1)\)和\((x_2,y_2)\),那么就對應地會有:

\(\begin{cases} y_1=ax_1^2+bx_1\\ \\y_2=ax_2^2+bx_2\end{cases}\)

這里有一個很明顯的矩陣關(guān)系:

\(\left[\begin{matrix}\ y_1\ \\ \\y_2\end{matrix}\right]=\left[\begin{matrix}\ x_1^2&x_1\ \\ \\x_2^2&x_2\end{matrix}\right]\times\left[\begin{matrix}\ a\ \\ \\b\end{matrix}\right]\)

于是有:

\(\left[\begin{matrix}\ a\ \\ \\b\end{matrix}\right]=\left[\begin{matrix}\ x_1^2&x_1\ \\ \\x_2^2&x_2\end{matrix}\right]^{-1}\times\left[\begin{matrix}\ y_1\ \\ \\y_2\end{matrix}\right]\)

又因為:

\(\left|\begin{matrix}\ x_1^2&x_1\\ \\x_2^2&x_2\end{matrix}\right|=x_1^2x_2-x_1x_2^2=(x_1-x_2)x_1x_2\)

所以有:

\(\left[\begin{matrix}\ x_1^2&x_1\ \\ \\ x_2^2&x_2\end{matrix}\right]^{-1}=\frac{1}{(x_1-x_2)x_1x_2}\left[\begin{matrix}\ x_2&-x_1\ \\ \\-x_2^2&x_1^2\end{matrix}\right]\)

(逆矩陣的求法)

所以有:

\(\left[\begin{matrix}\ a\ \\ \\b\end{matrix}\right]={1\over(x_1-x_2)x_1x_2}\left[\begin{matrix}\ x_2&-x_1\ \\ \\-x_2^2&x_1^2\end{matrix}\right]\times\left[\begin{matrix}\ y_1\ \\ \\y_2\end{matrix}\right]\)

即:

\(\begin{cases}a={1\over(x_1-x_2)x_1x_2}\times(x_2y_1-x_1y_2)\\ \\b={1\over(x_1-x_2)x_1x_2}\times(x_1^2y_2-x_2^2y_1)\end{cases}\)


還有一件事

我們對于拋物線,在后面枚舉狀態(tài)的時候是不需要知道除了能打的小豬以外的所有信息

所以直接維護這個信息就可以了,其他都沒有必要維護

這個眾位大犇可以直接一下本蒟蒻的代碼


【代碼】

那本蒟蒻就放代碼了:

#include<cstdio>
#include<cstring>
using namespace std;
#define min(a,b) ((a<b)?a:b)
inline void built(double &a,double &b,double x1,double y1,double x2,double y2){
a=(x2*y1-x1*y2)/(x1*x2*(x1-x2));
b=(x1*x1*y2-x2*x2*y1)/(x1*x2*(x1-x2));
}//計算a,b
inline bool inc(double a,double b,double x,double y){
double abs=a*x*x+b*x-y;
if(abs<0) abs=-abs;
return abs<=0.000001;
}//判定某個小豬是否在拋物線上
inline int read(){
int ans=0;char c=getchar();bool neg=0;
while((c<'0')|(c>'9')) { neg^=!(c^'-'); c=getchar(); }
while((c>='0')&(c<='9')) { ans=(ans<<3)+(ans<<1)+c-'0'; c=getchar(); }
return neg?-ans:ans;
}//無聊的讀入優(yōu)化
int n,para[200],dp[1<<18],countpara;
inline void pre(){
memset(dp,0x3f,sizeof(dp));
countpara=0;
double x[18]={0},y[18]={0};
n=read();read();
for(int i=0;i<n;i++) scanf("%lf %lf",&x[i],&y[i]);
//dp定義為無限大,拋物線的條數(shù)清空,讀入
for(int i=0;i<n;i++){
para[countpara++]=(1<<i);
//只打一只小豬的
for(int j=i+1,vis=0;j<n;j++)//定義vis表示打到過的小豬,避免重復枚舉
if((vis>>j)&1) continue;
else{
double a,b;
built(a,b,x[i],y[i],x[j],y[j]);
if(a>=0) continue;
para[countpara]=(1<<i);
for(int k=j;k<n;k++)//枚舉小豬,查看是否在線上
if(inc(a,b,x[k],y[k])){
vis|=(1<<k);
para[countpara]|=(1<<k);
}
countpara++;
}
}
}
inline int ans(){//狀壓
dp[0]=0;
for(int i=0;i<(1<<n);i++)
for(int j=0;j<countpara;j++)
dp[i|para[j]]=min(dp[i|para[j]],dp[i]+1);
return dp[(1<<n)-1];
}
int main(){
int t=read();
while(t--){
pre();//先皮一下
printf("%d\n",ans());
}
return 0;
}

最后安利一下 本蒟蒻的博客

總結(jié)

以上是生活随笔為你收集整理的题解 P2831 【愤怒的小鸟】的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 伊人久久大香 | 蜜桃久久一区二区三区 | 日韩av无码一区二区三区 | 久久久久久黄色片 | 国产亚洲精品久久 | 快播日韩 | 希岛婚前侵犯中文字幕在线 | 国产又粗又长又爽 | 毛片毛片毛片毛片毛片毛片毛片毛片毛片毛片 | 久久久久久一区二区三区 | 欧美视频在线一区二区三区 | 国产日韩欧美中文 | 给我看免费高清在线观看 | a√天堂在线 | 熊猫电影yy8y全部免费观看 | 久久精品—区二区三区舞蹈 | 性a视频 | 国产精品无码无卡无需播放器 | 国产无遮挡又黄又爽又色 | 欧美国产三级 | 性史性农村dvd毛片 日韩精品在线视频观看 | 久久九| 在线免费观看不卡av | 欧洲在线视频 | 亚洲最大av | 天堂中文网在线 | 播播网色播播 | 猛1被调教成公厕尿便失禁网站 | 高h调教冰块play男男双性文 | 一级做a免费 | 日韩av成人在线 | 最新国产一区 | 91网入口| 香蕉国产在线 | 制服丝袜在线第一页 | 国产成人精品亚洲男人的天堂 | 中文字幕在线永久 | 久久久夜色精品亚洲 | 麻豆精品影院 | 久久国产综合 | 天干夜夜爽爽日日日日 | 国内av网 | 精品久久久久久久久久 | 在线观看日韩av电影 | 粉嫩av蜜桃av蜜臀av | 国产裸体视频网站 | 欧美hdse | 成人免费午夜 | 青草伊人网 | 可以免费观看的毛片 | 亚洲欧洲天堂 | 依依成人在线 | 最好看的电影2019中文字幕 | 国产农村妇女精品一二区 | 性色av一区二区三区在线观看 | 国产福利免费观看 | 亚洲精品一区二区三区蜜臀 | 久久久av免费 | 篠田优在线观看 | 黄色a级在线观看 | 国产网站在线免费观看 | 91人人草| 不卡精品| 西西人体www大胆高清 | 亚洲av中文无码乱人伦在线视色 | 欧美三级在线看 | 美女av网址 | 新红楼梦2005锦江版高清在线观看 | 中文字幕人妻丝袜二区 | 丰满人妻一区二区三区在线 | 美女毛毛片 | 露出调教羞耻91九色 | 日本打屁股网站 | 久久艹这里只有精品 | 日韩中文字幕第一页 | 高清一区二区视频 | 国产三级在线观看完整版 | 中文字幕在线观看国产 | 动漫av网站免费观看 | 一区二区三区精品在线观看 | 中文字幕在线观看网站 | 成年人小视频在线观看 | av黄色在线观看 | 狠狠草视频 | 亚洲人视频在线 | 毛片视频网站在线观看 | 亚洲精品乱码久久久久久自慰 | 精品久久久久久久久久 | 国产精品无码网站 | av美女在线 | 香蕉中文网 | 涩色视频 | 日本一区二区三区在线观看 | 最新中文字幕在线观看视频 | 免费看黄色一级大片 | 亚欧综合在线 | 国产伦一区二区 | 亚洲一区二区偷拍 | 日本五十路在线 |