比赛 csp2025模拟练习2 评测结果 AAAAAAAAWWWWAAWAATAT
题目名称 愤怒的小鸟 最终得分 65
用户昵称 梦那边的美好TT 运行时间 8.502 s
代码语言 C++ 内存使用 5.81 MiB
提交时间 2025-10-29 10:57:05
显示代码纯文本
#include<bits/stdc++.h>
#define ll long long
#define N 19
using namespace std;
int t,n,mm,dp[1<<N];
map<pair<double,double>,int> m;
struct node{
	double x,y;
}a[N];
bool cmp(node aa,node bb){
	if(aa.x==bb.x) return aa.y<bb.y;
	return aa.x<bb.x;
}
int main(){
	freopen("angrybirds.in","r",stdin);
	freopen("angrybirds.out","w",stdout);
	ios::sync_with_stdio(false);
	cin.tie(0);
	cin>>t;
	while(t--){
		cin>>n>>mm;
		m.clear();
		for(int i=0;i<n;i++) cin>>a[i].x>>a[i].y;
		sort(a,a+n,cmp);
		for(int i=0;i<n;i++){
			for(int j=0;j<n;j++){
				if(i==j) continue;
				double x1=a[i].x,y1=a[i].y,x2=a[j].x,y2=a[j].y;
				if(fabs(x1-x2)<1e-8) continue;
				double k1=(y1*x2-y2*x1)/(x1*x1*x2-x2*x2*x1),k2=(y1-k1*x1*x1)/x1;
				if(k1>=0) continue;
				if(m.find({k1,k2})==m.end()){
					int mk=0;
					for(int k=0;k<n;k++){
						double fz=k1*a[k].x*a[k].x+k2*a[k].x;
						if(fabs(fz-a[k].y)<1e-6) mk|=(1<<k);
					}
					m[{k1,k2}]=mk;
				}
			}
		}
		for(int i=0;i<n;i++) m[{0.0+i,0.0}]=1<<i;
		memset(dp,0x3f,sizeof(dp));
		dp[0]=0;
		for(int i=0;i<(1<<n);i++){
			if(dp[i]==0x3f) continue;
			for(auto it:m) dp[i|it.second]=min(dp[i|it.second],dp[i]+1);
		}
		cout<<dp[(1<<n)-1]<<endl;
	}
	return 0;
}