传送门

我数学可能白学了……

因为三个数加起来等于\(1\),那么只要用前两个数就能表示,那么就能把每一种金属看成一个二维向量。考虑只有两个向量的时候,设这两个向量为\(a,b\),那么一个向量\(c\)能被表示也就是说存在\(ax+by=c\)且\(x+y=1\),根据数学老师说的那么\(c\)在\(a\)和\(b\)的终点连成的直线上,那么这里因为\(x\)和\(y\)非负所以是在这条线段上。推广一下(我也不知道怎么推广),有\(n\)个向量的时候能表示的范围就在这\(n\)个点的凸包里

于是就转化为求一个合金构成的点数最少的凸包且要完全包住顾客的凸包

那么就枚举所有的点对,如果所有顾客都在\((i,j)\)这条边的同一侧,那么就加入这条边。最后跑一个floyd求最小环

//minamoto
#include<bits/stdc++.h>
#define fp(i,a,b) for(register int i=a,I=b+1;i<I;++i)
#define fd(i,a,b) for(register int i=a,I=b-1;i>I;--i)
#define eps 1e-10
using namespace std;
template<class T>inline bool cmin(T&a,const T&b){return a>b?a=b,1:0;}
const int N=505;
struct node{
double x,y;
node(){}
node(double x,double y):x(x),y(y){}
}p[N],e[N];
double cross(node a,node b,node c){return (b.x-a.x)*(c.y-a.y)-(c.x-a.x)*(b.y-a.y);}
inline bool check(node a,node b,node c){return (a.x>c.x&&b.x>c.x)||(a.x<c.x&&b.x<c.x)||(a.y>c.y&&b.y>c.y)||(a.y<c.y&&b.y<c.y);}
int g[N][N];bool flag;double res;int mn=0x3f3f3f3f;
//inline double abs(double x){return x<0?-x:x;}
int main(){
// freopen("testdata.in","r",stdin);
int n,m;scanf("%d%d",&m,&n);
fp(i,1,m)scanf("%lf%lf%lf",&e[i].x,&e[i].y,&res);
fp(i,1,n)scanf("%lf%lf%lf",&p[i].x,&p[i].y,&res);
fp(i,1,m){
flag=true;
fp(j,1,n)if(abs(e[i].x-p[j].x)>eps||abs(e[i].y-p[j].y)>eps){flag=false;break;}
if(flag)return puts("1"),0;
}
memset(g,0x3f,sizeof(g));
fp(i,1,m)fp(j,1,m)if(i!=j){
if(abs(e[i].x-e[j].x<eps)&&abs(e[i].y-e[j].y)<eps)continue;
flag=true;
fp(k,1,n)if(cross(e[i],e[j],p[k])<-eps){flag=false;break;}
if(!flag)continue;
fp(k,1,n){
res=cross(e[i],e[j],p[k]);
if(res<eps&&res>-eps&&check(e[i],e[j],p[k])){flag=false;break;}
}
if(flag)g[i][j]=1;
}
fp(k,1,m)fp(i,1,m)fp(j,1,m)cmin(g[i][j],g[i][k]+g[k][j]);
fp(i,1,m)fp(j,1,m)
cmin(mn,i==j?g[i][j]:g[i][j]+g[j][i]);
printf("%d\n",mn>m?-1:mn);return 0;
}

最新文章

  1. Scala入门之函数
  2. VS2010--2013使用技巧及使用过程中遇到的问题
  3. 用C语言写的双色球
  4. Oracle创建表
  5. Spark RDD/Core 编程 API入门系列 之rdd案例(map、filter、flatMap、groupByKey、reduceByKey、join、cogroupy等)(四)
  6. linux 提高进程优先级nice+ 进程调度CFS
  7. LINUX的命令(未完待续)
  8. GLSL 纹理贴图
  9. 2014年第五届蓝桥杯javaB组 试题 答案 解析
  10. python使用urllib2 http 下载参数的try catch
  11. win10.64位wnmp-nginx1.14.0 + PHP 5. 6.36 + MySQL 5.5.59 环境配置搭建 结合Thinkphp3.2.3
  12. swift 实践- 07 -- UISwitch 开关
  13. 实践出真知-所谓&quot;java没有指针&quot;,那叫做引用!
  14. nginx反向代理实例
  15. 百度编辑器ueditor 字符限制
  16. 实现Spring管理struts的Action
  17. css3 flex属性flex-grow、flex-shrink、flex-basis学习笔记
  18. Linux gtypist
  19. 【c学习-12】
  20. 《深入理解Spark-核心思想与源码分析》(三)第三章SparkContext的初始化

热门文章

  1. axios在vue项目中的一种封装方法
  2. python使用xlrd和xlwt读写Excel文件
  3. Jmeter使用基础笔记-写一个http请求
  4. Maven_自动化构建和构建环节
  5. Cow Sorting POJ 3270 &amp; HDU 2838
  6. nyoj 63 小猴子下落
  7. nyoj 95 众数问题(set)
  8. apt-get使用指南
  9. IBOutlet loadView UIButton的subview数量 UIWebView
  10. Java中原始数据类型存放位置理解